创建了一个Java多线程服务器,通过socket连接不断接收大量设备(客户端)传输过来的信息
// 创建可以容纳4个线程的线程池
ExecutorService fixedThreadPool = Executors.newFixedThreadPool(4);
当连接数达到4个时出现了阻塞状态,求解怎么解决,怎么在完成一次数据解析后释放工作线程接收下一个连接,有点卡壳
创建了一个Java多线程服务器,通过socket连接不断接收大量设备(客户端)传输过来的信息
// 创建可以容纳4个线程的线程池
ExecutorService fixedThreadPool = Executors.newFixedThreadPool(4);
当连接数达到4个时出现了阻塞状态,求解怎么解决,怎么在完成一次数据解析后释放工作线程接收下一个连接,有点卡壳
这是因为你的线程池只有4个线程,这样当4个线程都在工作的时候,你新来的任务就要阻塞等待其他线程完成工作才能进入工作状态。
你只要让你的工作线程函数完成任务后就返回,不要阻塞在里面