Java NIO简述

2017-02-12  本文已影响87人  平凡的小Y

概述

Java NIO(New IO)是一个可以替代标准Java IO API的IO API(从Java 1.4开始),Java NIO提供了与标准IO不同的IO工作方式。

I/O模型

BIO、NIO、AIO

Java NIO由以下几个核心部分组成:

channel

Java NIO的通道类似流,但又有些不同:

Channel的实现

Buffer

Java NIO中的Buffer用于和NIO通道进行交互。如你所知,数据是从通道读入缓冲区,从缓冲区写入到通道中的。
缓冲区本质上是一块可以写入数据,然后可以从中读取数据的内存。这块内存被包装成NIO Buffer对象,并提供了一组方法,用来方便的访问该块内存。

Selector

Selector是Java NIO中能够检测一到多个NIO通道,并能够知晓通道是否为诸如读写事件做好准备的组件。这样,一个单独的线程可以管理多个channel,从而管理多个网络连接。


selectors.png

要使用Selector,得向Selector注册Channel,然后调用它的select()方法。这个方法会一直阻塞到某个注册的通道有事件就绪。一旦这个方法返回,线程就可以处理这些事件,事件的例子有如新连接进来,数据接收等。

Selector的创建

Selector selector = Selector.open();

向Selector注册通道

// 与Selector一起使用时,Channel必须处于非阻塞模式下
channel.configureBlocking(false);
SelectionKey key = channel.register(selector,Selectionkey.OP_READ);

通过Selector选择通道:一旦向Selector注册了一或多个通道,就可以调用几个重载的select()方法。这些方法返回你所感兴趣的事件(如连接、接受、读或写)已经准备就绪的那些通道

int select() //阻塞到至少有一个通道在你注册的事件上就绪了
int select(long timeout) //和select()一样,除了最长会阻塞timeout毫秒(参数)
int selectNow()  //不会阻塞,不管什么通道就绪都立刻返回

博客:http://yany8060.xyz/

上一篇下一篇

猜你喜欢

热点阅读