美文网首页
io和Java Nio、Aio

io和Java Nio、Aio

作者: 慕容小伟 | 来源:发表于2018-05-17 14:33 被阅读23次

    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

    來源:简书

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

    相关文章

      网友评论

          本文标题:io和Java Nio、Aio

          本文链接:https://www.haomeiwen.com/subject/ruybdftx.html