多线程socket编程的问题,使用BIO模式的话,一个线程只能处理一个Socket吗?

我在做一些网络编程相关的学习,写了一个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关闭?
那么在很多个客户端的情况下,线程数不会爆炸多吗?
求解。

写一个循环,来一个连接,创建一个新的线程。这个是Bio常用的解决方式。
你可以用Nio。