Java面试题
BIO
阻塞IO。一个连接一个线程,当服务端接受到多个客户端的请求时,客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销
NIO
同步非阻塞IO。一个线程处理多个连接。NIO 包含 Channel(通道)、Selector(选择器)、Buffer (缓冲区)三个核心组件。NIO是面向缓冲区的,所有的数据都是在Buffer 缓冲区里。Channel是一个通道,可以通过他读取或写入数据,通道和流的不同是,通道是双向的,而流只能朝着一个方向移动。Selector选择器通过轮询来监听多个Channel通道,如此实现一个线程管理多个连接。
适用场景:连接数目多且连接比较短(轻操作)的架构,比如聊天服务器,弹幕系统,服务器间通讯等。
使用案例:Jetty、Dubbo、Zookeeper等都是基于NIO实现。
AIO
异步非阻塞IO。一个有效请求一个线程。流的读写都是异步执行,当流读取或写入完毕后,操作系统通知服务器启动线程进行处理。文章来源:https://www.toymoban.com/news/detail-808854.html
适用场景:连接数目多且连接比较长的架构,比如相册服务器,充分调用 OS 参与并发操作文章来源地址https://www.toymoban.com/news/detail-808854.html
到了这里,关于BIO、NIO、AIO 的区别的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!