JDK在1.4以后对传统的面向流的I/O操作作了很大的优化,传统I/O是面向流的,字节流或者字符流,而且每当我们在调用read()或者write()方法的时候就会一直等待在那个地方,知道资源可用位置。这很大程度上限制了I/O的效率。
JDK1.4以后引入了新的I/O操作的实现NIO(新的input/output),NIO的核心内容是:缓冲区buffer,通道channel,选择器Selector。
所谓缓冲区Buffer:
一段固定长度的内存空间,用来存放数据,可以向缓冲区中写入数据,也可以冲缓冲区中读取数据。
(1)容量(capacity):表示该缓冲区能够写入和读取的最大数量,穿件Buffer的时候设定 allocate(int capacity)方法。
(2)上界(Limit):缓冲区第一个不能被读取和写入的位置
(3)位置(Position):下一个读取和写入的位置
ByeBuffer :字节
CharBuffer:字符
ShortBuffer:short类型
IntBuffer :int类型
LongBuffer:long类型
DoubleBuffer :double类型
FloatBuffer:float类型
通道Channel
传统的IO是面向流的单向的数据传输,新的IO是面向通道的,通道是双向的。通道时连接缓冲区和IO服务之间的一个通道。
FileChannel:文件通道
DatagramChannel:UDP通信的通道
ServerSocketChannel:TCP服务器端通道
SocketChannel:TCP客户端通道
选择器Selector
选择器的实现模式用到了java中的观察者模式,一个选择器上面可以注册很多的通道,然后通过选择器一个线程就可以管理很多通道,目前选择器是通过轮询的方式来监控通道的状态的。