Java NIO概览

Java NIO 包含下列几个核心组件:

Channels
Buffers
Selectors

   Java NIO还有很多类和组件,而不仅仅是这几个,但是Channel,BufferSelector构成了NIO的核心API。其他的组件如:PipeFileLock是为了更好的使用这三个核心组件。
因此,这个章节中,我主要是关注这三个组件。其他组件将在后续的章节中进行讲解。

Channels和Buffers

    通常,所有NIO中的IO都是从一个Channel中开始的,一个Channel就像是一个stream。数据可以从Channel读取到一个Buffer中。数据也可以从一个Buffer写入到一个Channel中。
下图是一个例子:


overview-channels-buffers.png

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的阐述:


overview-selectors.png

   使用Selector之前,你首先得将Channel注册到其上,之后再调用Selector的select()方法。这个方法将阻塞直到注册的Channel中某个Channel有数据为止,一旦方法返回,线程就可以处理这些数据了。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的Java I...
    JackChen1024阅读 7,582评论 1 143
  • Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的Java I...
    编码前线阅读 2,289评论 0 5
  • Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的Java I...
    zhisheng_blog阅读 1,133评论 0 7
  • 来自专栏鉴峰笔记 鉴峰自我管理 [连续签到第176天] 2018-7-3 周二 鉴峰笔记之勇敢: 你我一生, 总是...
    鉴峰笔记阅读 131评论 0 0
  • 二年级八班郑文轩 今天是星期六,妈妈说做饭时间比较宽裕,可以教我做一道小凉菜。我和妈妈把需要的藕、胡萝卜、芹菜洗干...
    于淑玲阅读 232评论 0 0