BIO、NIO、AIO、多路复用IO的区别(图解) 4年前

原文地址:blog.csdn.net/lzb348110175/article/details/98941378

学习之前,我们先来了解一下IO模型:

       ①同步阻塞IO(Blocking IO):即传统的IO模型。

       ②同步非阻塞IO(Non-blocking IO):默认创建的socket都是阻塞的,非阻塞IO要求socket被设置为NONBLOCK。注意这里所说的NIO并非Java的NIO(New IO)库。

       ③多路复用IO(IO Multiplexing):即经典的Reactor设计模式,有时也称为异步阻塞IO,Java中的Selector和Linux中的epoll都是这种模型(Redis单线程为什么速度还那么快,就是因为用了多路复用IO和缓存操作的原因)

       ④异步IO(Asynchronous IO):即经典的Proactor设计模式,也称为异步非阻塞IO。


图解:

看了这些,你应该对这些IO有了新的认识了吧,那就给我个赞呗^_^

本文分享自微信公众号 - JAVA高级架构(gaojijiagou)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

名字的名字叫名字
还可以想象一对热恋中的情人,互相一次次说“我一刻也不想离开你”,又互相一次次说“时间已经不早了”,时间不早了可我一刻也不想离开你,一刻也不想离开你可时间毕竟是不早了。
3
发布数
2
关注者
8358
累计阅读

热门教程文档

Objective-C
29小节
C
14小节
MySQL
34小节
Swift
54小节
Java
12小节
广告