BIO、NIO、AIO 的区别

Java面试题

BIO

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

NIO

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

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

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

AIO

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

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

相关推荐
小小小米粒7 分钟前
Maven Tools
java
kali-Myon21 分钟前
2025春秋杯网络安全联赛冬季赛-day1
java·sql·安全·web安全·ai·php·web
我是咸鱼不闲呀24 分钟前
力扣Hot100系列20(Java)——[动态规划]总结(下)( 单词拆分,最大递增子序列,乘积最大子数组 ,分割等和子集,最长有效括号)
java·leetcode·动态规划
清水白石00834 分钟前
深入解析 LRU 缓存:从 `@lru_cache` 到手动实现的完整指南
java·python·spring·缓存
符哥20081 小时前
C++ 进阶知识点整理
java·开发语言·jvm
Sayuanni%31 小时前
初阶_多线程1(线程含义与关键属性)
java
程序媛徐师姐1 小时前
Java基于微信小程序的模拟考试系统,附源码+文档说明
java·微信小程序·java模拟考试系统小程序·模拟考试微信小程序·模拟考试系统小程序·模拟考试小程序·java模拟考试小程序
疯狂敲代码的老刘1 小时前
JDK 1.6到25 全版本网盘合集 (Windows + Mac + Linux)
java·linux·windows·macos·jdk
夕除1 小时前
js--15
java·jvm·spring
曾经的三心草1 小时前
redis-9-集群
java·redis·mybatis