java之BIO NIO AIO
java之BIO NIO AIO
-
BIO: 同步阻塞IO模型:数据的读取写入必须阻塞在一个线程内等待其完成。
-
NIO :同步非阻塞I/O模型
-
定义:同步非阻塞,服务实现模式是一个线程可以处理多个连接,即客户端发送的连接都会注册到多路复用器上,然后进行轮询连接,有I/O请求就处理。
-
三大核心内容:Selector(选择器)、Channel(通道)、Buffer(缓冲区)。
-
selector:用于监听多个Channel的事件,并对检测到的I/O事件进行相应的响应和处理。
-
Channel:双向的,既可以进行读操作,也可以进行写操作。
-
Buffer:本质是个容器、其内部通过一个连续的字节数组存储I/O上的数据。
-
-
AIO:异步非阻塞I/O模型:AIO 也就是 NIO 2,在 Java 7 中引⼊了 NIO 的改进版 NIO 2,它 是异步⾮阻塞的 IO 模型。异步 IO 是基于事件和回调机制实现的,也就是应⽤操作之后会直 接返回,不会堵塞在那⾥,当后台处理完成,操作系统会通知相应的线程进⾏后续的操作
BIO | NIO | AIO | |
---|---|---|---|
IO模型 | 同步阻塞 | 同步非阻塞(多路复用) | 异步非阻塞 |
面向流(Stream) | 面向缓冲区块(Buffer)【效率:块》流】 | ||
应用场景 | 适用连接数目比较小且固定的架构,对服务器要求比较高,并发局限于应用中 | 适用连接数目多且连接比较短的架构,如:聊天服务器,弹幕系统等,编程比较复杂 | 适用连接数目多且连接长的架构,如相册服务器 |
脚踏实地,注重基础。