这里写自定义目录标题
java网络编程之BIO与NIO阻塞与非阻塞的比较
(1)BIO获取连接时虽然也是以阻塞的方式:
Socket request = serverSocket.accept();// 阻塞
但这不是重点,因为无论BIO还是NIO,都是阻塞地获取连接。这个阻塞是指在没有连接到来时一直等待,是很合理的。
BIO的阻塞在于读取数据的阻塞,如以下代码:
InputStream inputStream = request.getInputStream(); // net + i/o
BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream, “utf-8”));
String msg;
while ((msg = reader.readLine()) != null) { // 没有数据,阻塞
if (msg.length() == 0) {
break;
}
System.out.println(msg);
(2)NIO以非阻塞的方式读取数据,它是用ByteBuffer来读取数据而不是用输入输出流的形式,前者在没有数据读取时可以不用等待,后者则会一直等待除非连接关闭:
if (ch.read(requestBuffer) == 0) {
// 等于0,代表这个通道没有数据需要处理,那就待会再处理
continue;
}
当然,NIO默认也是阻塞的,需要手动设置为非阻塞:
serverSocketChannel.configureBlocking(false); // 设置为非阻塞模式
socketChannel.configureBlocking(false);
NIO可以采用selecter选择器注册通道的方式,监听事件,这样在处理多个连接时,就不用轮询通道了,而是轮询事件,使得代码逻辑变得简单了。不只如此,也实现了非阻塞的方式读取数据,即只在有数据到来时才监听得到读事件。意思是NIO的非阻塞体现在两个方面:ByteBuffer和selecter选择器。