引言
Java NIO (New IO,或Non Blocking IO) 是从Java1.4 版本开始引入的一个新的 IO API,可以代替标准的Java IO API。
NIO与原来的IO有同样的作用和目的,但是使用的方式完全不同。
NIO支持面向缓冲区、基于通道的IO操作。NIO将以更加高效的方式进行文件的读写操作。
一、NIO 与 IO 的主要区别
IO | NIO |
---|---|
面向流(Stream Oriented) | 面向缓冲区(Buffer Oriented) |
阻塞IO(Blocking IO) | 非阻塞IO(Non-Blocking IO) |
无 | 选择器(Selectors) |
面向流指的是输入输出是基于“流”的概念,而且,流是单向的,不管输入还是输出都必须使用对应的输入流和输出流。流的本身也是数据在传输当中的一种抽象形式。
在NIO 中有通道(channel)的概念,是输出端和输入端之间的桥梁。虽然流也有类似的含义,但是不同的是,通道仅仅作为连接,本身不包含任何数据。与之进行配合使用的是缓冲区(Buffer)。如果把通道理解为铁路,那么缓冲区就可以是火车。NIO中的“通道 + 缓冲区”的组合可以完成双向传输的目的。
阻塞与非阻塞、选择器都是针对网络通信而言的。后面的网络通讯会详细讲解。
二、通道(Channel)和缓冲区(Buffer)
Java NIO 系统的核心在于:通道和缓冲区。
通道表示打开到IO 设备(文件、套接字)的连接。若需要使用NIO 系统,就必须要获取连接 IO 设备的通道以及用于容纳数据的缓冲区,然后操作缓冲区,对数据进行操作。
简而言之,Channel 负责传输, Buffer 负责存储。