一张图解决NIO原理

BIO

阻塞式IO

BIO模型
image

我们可以看到BIO模型中有两处阻塞的地方,第一是socket一直等待请求的到来,第二是read()函数等到数据已读取完。所以当我们用BIO的时候通常会开很多线程来阻止这样的阻塞发生,但是这样会导致大量的性能开销。所以NIO就是想要解决这个问题,提出的思考是:我们可不可以用一个线程解决第二个阻塞问题?下面我们就来看看NIO

NIO

同步非阻塞IO

NIO模型的提出

我们在数据的读取这一步遇到了阻塞原因是BIO需要等待数据读取完,比如1,2,3中,等待3被读取,NIO突破口在这,它只需要读完连续的数据包即例子中的1就直接返回去处理其他事件而不用阻塞了,但是后面的数据包2,3来的时候如何处理,此时就需要我们的观察者模式了,当探查到2,3到来的时候,可以让某个对象发出通知给读取者继续读取,这个对象就是所谓的selector,但是为了让读取者一直在线,可能通道channel是一种非常好的选择。所以通过以上分析,它的大概模型如下

image

大概解释一下,该模型收到报文1的时候,执行read操作,然后读取完后,不用等待数据完成,直接返回,执行b的一步,当报文2来的时候,通过注册的事件,继续对应的read操作即可。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • NIO 新的输入/输出 (NIO) 库是在 JDK 1.4 中引入的,弥补了原来的 I/O 的不足,提供了高速的、...
    脆皮鸡大虾阅读 2,981评论 0 0
  • 熟练掌握 BIO,NIO,AIO 的基本概念以及一些常见问题是你准备面试的过程中不可或缺的一部分,另外这些知识点也...
    小王学java阅读 6,218评论 0 0
  • NIO(Non-blocking I/O,在Java领域,也称为New I/O),是一种同步非阻塞的I/O模型,也...
    Demon_code阅读 3,134评论 0 0
  • “家门口那家卖包子的,八年了,每天早上六点多就开门,一直到晚上九点多才关门;菜市场后面那个卖凉皮、米线的老头,整整...
    刺客丶阅读 1,409评论 0 0
  • 门前 文/党爱元 那个春天 奶奶依在用篱笆扎成得 老院的门前 眼里透射着 一种希望 兰花在门前的 水沟旁,疯长 一...
    落寞在凉州的烟雨里阅读 1,747评论 0 4

友情链接更多精彩内容