我在做一些网络编程相关的学习,写了一个Demo,类似于一个聊天室,有一个WebServer,多个Client,当Client发起连接时,Server创建一个线程来处理,由于Client特别多,我打算使用固定的5个线程来处理这些所有的Client,也就意味着一个线程可能负责处理多个Socket。
我原本的打算是一个Client轮询地去读取每个Socket的字节流,后来发现行不通,在读取第一个Socket的输入流时就卡住了,完全是阻塞的。
代码如下:
public void handle() throws IOException, InvalidProtocolException {
byte[] buf = new byte[1024];
StringBuilder sb = new StringBuilder();
int readLength;
try {
for(;;){
readLength = in.read(buf);
if (readLength > 0) {
sb.append(new String(buf, 0, readLength));
} else {
break;
}
}
parse(sb.toString());
} catch (IOException e1) {
throw e1;
} catch (InvalidProtocolException e2) {
throw e2;
}
}
在in.read这一行处,完全被阻塞,无法做到轮询。
那么是否意味着使用BIO时,一个线程只能处理一个Socket,直到这个Socket关闭?
那么在很多个客户端的情况下,线程数不会爆炸多吗?
求解。