BIO、NIO、AIO 的区别

Java面试题

BIO

阻塞IO。一个连接一个线程,当服务端接受到多个客户端的请求时,客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销

NIO

同步非阻塞IO 。一个线程处理多个连接。NIO 包含 Channel(通道)、Selector(选择器)、Buffer (缓冲区)三个核心组件。NIO是面向缓冲区的,所有的数据都是在Buffer 缓冲区里。Channel是一个通道,可以通过他读取或写入数据,通道和流的不同是,通道是双向的,而流只能朝着一个方向移动。Selector选择器通过轮询来监听多个Channel通道,如此实现一个线程管理多个连接。

适用场景:连接数目多且连接比较短(轻操作)的架构,比如聊天服务器,弹幕系统,服务器间通讯等。

使用案例:Jetty、Dubbo、Zookeeper等都是基于NIO实现。

AIO

异步非阻塞IO。一个有效请求一个线程。流的读写都是异步执行,当流读取或写入完毕后,操作系统通知服务器启动线程进行处理。

适用场景:连接数目多且连接比较长的架构,比如相册服务器,充分调用 OS 参与并发操作

相关推荐
qq_1955516922 分钟前
代码随想录70期day7
java·开发语言
Sam-August1 小时前
【分布式架构实战】Spring Cloud 与 Dubbo 深度对比:从架构到实战,谁才是微服务的王者?
java·spring cloud·dubbo
麦兜*1 小时前
MongoDB 常见错误解决方案:从连接失败到主从同步问题
java·数据库·spring boot·redis·mongodb·容器
ytadpole2 小时前
揭秘设计模式:命令模式-告别混乱,打造优雅可扩展的代码
java·设计模式
用户3721574261352 小时前
Java 教程:轻松实现 Excel 与 CSV 互转 (含批量转换)
java
叫我阿柒啊2 小时前
Java全栈开发实战:从基础到微服务的深度解析
java·微服务·kafka·vue3·springboot·jwt·前端开发
凯尔萨厮2 小时前
Java学习笔记三(封装)
java·笔记·学习
霸道流氓气质2 小时前
Java开发中常用CollectionUtils方式,以及Spring中CollectionUtils常用方法示例
java·spring
失散132 小时前
分布式专题——5 大厂Redis高并发缓存架构实战与性能优化
java·redis·分布式·缓存·架构
通达的K2 小时前
Java实战项目演示代码及流的使用
java·开发语言·windows