IO模型的基本说明:

1.理解:就是用什么样的通道进行数据的发送和接收,很大程度上决定了程序通信的性能

2.java支持三种网络变成模型IO模式:BIO、NIO、AIO

3.java BIO:同步并阻塞(传统阻塞型)服务器实现模式为一个连接一个线程,即客户端有连接请求时,服务器端就会启动一个线程进行处理,如果这个连接不做任何事情就会造成不必要的线程开销

1.png

4.java NIO:同步非阻塞,服务器实现模式为一个线程处理多个请求(连接),即客户端发送的连接请求都会注册到多路复用器上,多路复用器轮询到连接有IO请求就进行处理

2.png

5.java AIO(NIO.2):异步非阻塞,AIO引入异步通道的概念,采用Proactor模式,简化了程序编写,有效的请求才启动线程,它的特点时是先由操作系统完成后才通知服务端程序启动线程去处理,一般适用于连接数较多且连接时间较长的应用


3.png