io和Java Nio、Aio

java的I/O是建立在流(stream)之上的,而流是同步的,当线程请求一个流读/写一段数据时,线程会一直阻塞下去,直到有数据、数据读写完毕或发生异常时线程才会被重新使用。


BIO编程的基本模型是Client/Server模型,也就是两个进程之间进行相互通信,其中服务器提供位置(ip,port)信息,客户端通过连接服务器监听的位置发请求,通过三次握手建立连接,若成功,则通过Socket进行通信,基于输入和输出流的同步阻塞式通信。



NIO(非阻塞I/O)编程

NIO是在JDK 1.4中引入的,人们习惯称呼为New I/O或非阻塞I/O(Non-block I/O),与原始Socket/ServerSocket类相对应,它提供了SocketChannel和ServerSocketChannel两种不同的套接字通道实现,与基于同步流的I/O不同,它提供了基于缓冲区Buffer的阻塞和非阻塞两种开发模式。要学习NIO首先得掌握它如下的几个核心概念

NIO缓冲区概念,上面提过,NIO是面向缓冲块的高速I/O,在面向流的I/O中,可以将数据直接写入或读取到Stream对象中,在NIO库中,所有数据都是通过缓冲区处理的。

缓冲区实质是一个数组


通道Channel

Channel是一个通道,网络数据通过channel读取和写入。通道与流的不同在于通道是双向的,支持阻塞和非阻塞两种模式。

多路复用器 Selector

Selector会轮询注册在其上的channel,如果某个channel发生读或写事件,这个channel就处于就绪状态,会被Selector轮询出来,然后通过SelectionKey获取已经就绪的channel集合,进行后续的I/O操作。

一个多路复用器Selector可以同时轮询多个Channel,一个线程负责Selector的轮询,就可以接入成千上万个客户端。


NIO是同步非阻塞IO,同步是因为复用器会不断轮询注册在其上的channel,但是相比于之前的同步阻塞I/O流,它是异步的,所以很多人也称呼NIO为异步非阻塞I/O,但实际上它是同步的。


四)AIO编程

NIO2.0引入AIO,提供了异步文件通道和异步套接字同步,实现了真正意义上的异步非阻塞I/O。它不需要通过多路复用器Selector对注册的通道进行轮训操作即可实现异步读写,从而简化了NIO的编程模型。

它提供两种方式来获取异步操作结果

通过Future类来表示异步操作的结果。

在执行异步操作时传入一个CompletionHandler接口的实现类作为操作完成的回调。

作者:miss2008

链接:https://www.jianshu.com/p/2db793d1c873

來源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容