《Java I/O 模型》专栏文章索引
《Java I/O 模型》Java BIO
《Java I/O 模型》Java NIO
《Java I/O 模型》Java AIO
在之前的两篇博客中,我们分别学习了传统的 Java BIO 和当今使用比较多的 Java NIO,那么最后一个阶段再简单了解一下 Java AIO 吧(由于种种原因,目前 Java AIO 使用的并不是很多,因此暂且简单的介绍一下)。
Java AIO(Asychronous I/O) 即 Java 异步非阻塞 I/O,JDK 1.7 开始支持,它是对 JDK1.4 中提出的同步非阻塞I/O(NIO) 的进一步增强。服务器实现模式为一个有效请求一个线程,客户端的 I/O 请求都是由操作系统先完成,完成之后再通知服务端应用去启动线程进行处理。它是基于 NIO 模式,因此又被称为 NIO 2.0.
简单地说,在 Java AIO 模式下:客户端发起请求之后不需要等待服务端响应可以做其他的事情,服务端处理完之后会将处理结果通知客户端,客户端这个时候会到指定的缓存区获取数据。
Java AIO 虽然是基于 Java NIO 的,但是与 Java NIO 又有些不同
在 Java AIO 中通道(Channel) 的接口是异步的,主要有四个异步通道
BIO、NIO、AIO 使用场景对比