四张图,读懂 BIO、NIO、AIO、多路复用 IO 的区别

点击上方☝码猿技术专栏 轻松关注,设为星标!

及时获取有趣有料的技术

作者:扛麻袋的少年

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 项目代码该如何分层?这个你肯定不知道

12 个顶级 Bug 跟踪工具

JetBrains出品,一款好用到爆的数据库工具,惊艳到了!!!

分布式事务中的时间戳详解

嘿,你在看吗

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值