java网络编程之netty原理浅析

这里写自定义目录标题


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选择器。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值