Java - NIO

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中的观察者模式,一个选择器上面可以注册很多的通道,然后通过选择器一个线程就可以管理很多通道,目前选择器是通过轮询的方式来监控通道的状态的。



你可能感兴趣的:(Java-NIO)