Fork me on GitHub

java之BIO NIO AIO

Java网络编程模型

java之BIO NIO AIO

  1. BIO同步阻塞IO模型:数据的读取写入必须阻塞在一个线程内等待其完成。

  2. NIO同步非阻塞I/O模型

    • 定义:同步非阻塞,服务实现模式是一个线程可以处理多个连接,即客户端发送的连接都会注册到多路复用器上,然后进行轮询连接,有I/O请求就处理。

    • 三大核心内容:Selector(选择器)、Channel(通道)、Buffer(缓冲区)。

    • selector:用于监听多个Channel的事件,并对检测到的I/O事件进行相应的响应和处理。

    • Channel:双向的,既可以进行读操作,也可以进行写操作。

    • Buffer:本质是个容器、其内部通过一个连续的字节数组存储I/O上的数据。

  3. AIO异步非阻塞I/O模型:AIO 也就是 NIO 2,在 Java 7 中引⼊了 NIO 的改进版 NIO 2,它 是异步⾮阻塞的 IO 模型。异步 IO 是基于事件和回调机制实现的,也就是应⽤操作之后会直 接返回,不会堵塞在那⾥,当后台处理完成,操作系统会通知相应的线程进⾏后续的操作

BIO NIO AIO
IO模型 同步阻塞 同步非阻塞(多路复用) 异步非阻塞
面向流(Stream) 面向缓冲区块(Buffer)【效率:块》流】
应用场景 适用连接数目比较小且固定的架构,对服务器要求比较高,并发局限于应用中 适用连接数目多且连接比较短的架构,如:聊天服务器,弹幕系统等,编程比较复杂 适用连接数目多且连接长的架构,如相册服务器
posted @ 2022-07-22 21:07  壶小旭  阅读(20)  评论(0编辑  收藏  举报