Java NIO(New IO)是一个可以替代标准Java IO API的IO API(从Java 1.4开始),Java NIO提供了与标准IO不同的IO工作方式。很多小伙伴可能和我一样,对于习惯了用IO来操作文件之后,对这个日渐流行的新东西会有不少的疑惑,那么阅读本文吧,和我一起打开NIO的大门,学习NIO操作文件。
一、NIO与IO的区别
下面有一个概要的区别图,图下面会有区别的描述。
IO NIO
面向流 面向缓冲
阻塞IO 非阻塞IO
无 选择器
Java IO中最为核心的一个概念是流(Steam),面向流的编程。流是信息的载体。IO中的一个流要么是输入流,要么是输出流,不可能同时是输入流和输出流。Java IO的各种流是阻塞的。这意味着,当一个线程调用read() 或 write()时,该线程被阻塞,直到有一些数据被读取,或数据完全写入。该线程在此期间不能再干任何事情了。
NIO是面向缓冲,数据读取到一个它稍后处理的缓冲区,需要时可在缓冲区中前后移动。这就增加了处理过程中的灵活性。Java NIO的非阻塞模式,使一个线程从某通道发送请求读取数据,但是它仅能得到目前可用的数据,如果目前没有数据可用时,就什么都不会获取。而不是保持线程阻塞,所以直至数据变的可以读取之前,该线程可以继续做其他的事情。 非阻塞写也是如此。
二、NIO的核心组件
NIO的核心包含三个重要组件:
1、Channel通道
Channel可以理解为IO的Stream流,每次读取数据,都是从通道中读取,写数据也是写入到通道,直接对接Buffer缓冲区。常见的通道有FileChannel,是文件的通道,用来读取文件,本文着重将这个通道。还有DataChannel,通过UDP读写网络数据,SocketChannel通过TCP读写网络数据,ServerSocketChannel监听新进来的TCP连接,对每一个新进来的TCP连接,都会建立一个SocketChannel。
通道可以实现双向读写ÿ