[英]Is it possible to make blocking java socket read non active waiting?
我有一个应用程序需要打开数千个套接字连接并等待消息。 客户端正在使用 java 阻塞套接字读取。 这意味着我将只能有 N 个并发打开的连接(基于线程集的执行程序数),因为所有 N 个线程都将在活动等待时被阻塞(RUNNABLE 状态)
有没有办法让这些套接字读取以在数据可用时“唤醒”线程(以与 NIO 套接字相同的方式)?
即当前行为线程池(4个线程)
没有更多的线程可以执行
期望行为线程池(4 个线程)
这样,另一个线程可以在其他线程等待时启动并执行数据可用的套接字读取
注意:我知道这可以通过 NIO 实现,但想知道如何将这种行为转移到旧版同步调用(如果可能)谢谢
答案是不。 java.net.SocketInputStream 的所有方法都是阻塞的。 InputStream.available() 没有实现并且总是返回 0。没有 NIO,唯一的方法是每个套接字使用一个线程。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.