NIO和IO对比

##1.NIO和IO区别
IO:以流为导向,阻塞IO。以Stream为导向
NIO:以缓冲区为导向,非阻塞IO,Buffer为导向,Selector选择器。

####阻塞IO是如何处理数据的呢?
先读取准备好的数据,等读取完,再读取下一条数据,以串行模式为主。

####而NIO是以Buffer(缓冲区),Thread(线程),Channel(通道)还有Selector(选择器)为配合而成,通常Channer会注册到Selector中,开始,Thread先把数据读取进Channel,然后Channel会把数据填充进Buffer,如果Channel要进行,那必须需要先通过Selector.selector(),然后会得到selectionkey的一个集合,通过这个集合可以了解哪个Channel读取了数据,在填充了数据之后,会进行检查数据,再处理数据,之后再循环操作,本质上还是串行模式。
但好处是只会在Channel有数据时读取,即时阻塞也只会阻塞在Selector.selector()。

在这里插入图片描述
在这里插入图片描述

###为什么读写分离会好一点?
计算机有一个网卡,网络的数据通过网卡读取或者输出,而网卡的读取是分离的,如果在上层也进行读取分离,那么在可拓展IO的带宽,更有利于数据的传输。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值