Java IO和NIO的区别

主要区别:
IO NIO
面向字节流 面向缓冲区
阻塞 基于Selector的非阻塞编程

Java IO 和 NIO的主要区别体如今以上两个方面,如下详细说明这些区别的具体含义。

面向流和面向缓冲区
这个概念和编程方法中的面向过程、面向对象相似。Java IO 是面向流的而Java NIO是面向缓冲区的。

在Java IO中读取数据和写入数据是面向流(Stream)的,这表示当咱们从流中读取数据,写入数据时也将其写入流,流的含义在于没有缓存 ,就好像咱们站在流水线前,全部的数据沿着流水线依次到达咱们的面前,咱们只能读取当前的数据(至关于咱们拥有一个数据流的切面)。若是须要获取某个数据的前一项或后一项数据那就必须本身缓存数据,而不能直接从流中获取(由于面向流就意味着咱们只有一个数据流的切面)

而在Java NIO中数据的读写是面向缓冲区(Buffer)的,读取时能够将整块的数据读取到缓冲区中,在写入时则能够将整个缓冲区中的数据一块儿写入。这就好像是将流水线传输变成了卡车运送,面向流的数据读写只提供了一个数据流切面,而面向缓冲区的IO则使咱们可以看到数据的上下文,也就是说在缓冲区中获取某项数据的前一项数据或者是后一项数据十分方便。这种便利是有代价的,由于咱们必须管理好缓冲区,这包括不能让新的数据覆盖了缓冲区中尚未被处理的有用数据;将缓冲区中的数据正确的分块,分清哪些被处理过哪些尚未等等。

Java NIO的IO模型与不少IO的本质更加一致!磁盘IO读写就是数据块读写; TCP/IP协议传输的也是数据包而不是数据流。可是不少系统提供的是倒是面向流的系统API,例如套接字API是面向数据流的。

阻塞和非阻塞
Java IO是阻塞的,若是在一次读写数据调用时数据尚未准备好,或者目前不可写,那么读写操做就会被阻塞直到数据准备好或目标可写为止。Java NIO则是非阻塞的,每一次数据读写调用都会当即返回,并将目前可读(或可写)的内容写入缓冲区或者从缓冲区中输出,即便当前没有可用数据,调用仍然会当即返回而且不对缓冲区作任何操做。这就好像去超市买东西,若是超市中没有须要的商品或者数量还不够,那么Java IO会一直等直到超市中须要的商品数量足够了就将全部须要的商品带回来,Java NIO则不一样,不论超市中有多少须要的商品,它都会当即买下能够买到的全部须要的商品并返回,甚至是没有须要的商品也会当即返回。

阻塞IO会使得线程将大量的时间浪费在等待IO上,这是很是不划算的,可是这种阻塞能够在数据可用时当即获取并处理数据,而非阻塞IO则必须经过重复的调用来获取所有数据。

Java NIO 使用Selector实现单线程管理多个Channel,经过 select 调用,能够获取已经准备好的Channel并进行相应的处理。

Java IO 工做流程
因为Java IO是阻塞的,因此当面对多个流的读写时须要多个线程处理。例如在网络IO中,Server端使用一个线程监听一个端口,一旦某个链接被accept,建立新的线程来处理新创建的链接。 



其中 read/write 是阻塞的。



Java NIO 工做流程
Java NIO 提供 Selector 实现单个线程管理多个channel的功能。

其中select 调用多是阻塞的,也能够是非阻塞的。可是read/write是非阻塞的!缓存

——本文转自CSDN网络

相关文章
相关标签/搜索