Java NIO 包含下列几个核心组件:
Channels
Buffers
Selectors
Java NIO还有很多类和组件,而不仅仅是这几个,但是Channel
,Buffer
和 Selector
构成了NIO的核心API。其他的组件如:Pipe
和FileLock
是为了更好的使用这三个核心组件。
因此,这个章节中,我主要是关注这三个组件。其他组件将在后续的章节中进行讲解。
Channels和Buffers
通常,所有NIO中的IO都是从一个Channel中开始的,一个Channel就像是一个stream。数据可以从Channel读取到一个Buffer中。数据也可以从一个Buffer写入到一个Channel中。
下图是一个例子:
Java NIO: Channel读取数据写入Buffer中,Buffer写数据到Channel中
这里有几个Channel和Buffer类型,下面是Java NIO中原始的Channel实现:
FileChannel
DatagramChannel
SocketChannel
ServerSocketChannel
如你所见这些Channel包含了UDP、TCP的网络IO以及文件的IO,这些类也有一些有趣的接口,但是为了简单期间,在本章中不打算讲解。在后续的文章中我们继续讲解。
下面是Java NIO的核心Buffer实现:
ByteBuffer
CharBuffer
DoubleBuffer
FloatBuffer
IntBuffer
LongBuffer
ShortBuffer
这些Buffer包含了可以通过IO传输的基本数据类型:byte、short、int、long、float、double和characters
Java NIO还有一个与内存映射文件一起使用的MappedByteBuffer,这个接口在后续章节再讲。
Selectors
一个Selector允许一个线程来处理多个Channel,当你的应用程序有很多链接但是每个链接的流量很少的时候,这是非常有用的,例如:聊天系统。
下图是一个线程使用一个Selector来处理3个Channel的阐述:
使用Selector之前,你首先得将Channel注册到其上,之后再调用Selector的select()方法。这个方法将阻塞直到注册的Channel中某个Channel有数据为止,一旦方法返回,线程就可以处理这些数据了。