Selector是SelectableChannel的多路选择器,配合SelectableChannel实现非阻塞IO. 详见代码

/**
* Selector 是 SelectableChannel的多路选择器</p>
* SelectableChannel 通过register函数注册到Selector上</p>
*
* Selector 维护三个key集合:</br>
* 1. 指代当前注册到selector上的channel的key集合</br>
* 执行register操作,将会把channel的key添加到集合中,key集合其本身不可直接修改</br>
* 2. selected-key集合,其中的key指代的channel上至少有一个在上一次selection期间可执行的操作</br>
* 执行select操作,将会把key添加到selected-key集合中.</br>
* 3. cancelled-key集合,其中的key已经被撤销但所指代的channel未从selector注销</br>
* 撤销的key所指代的channel在下一次select期间将会被注销.</br>
* 上述三个集合在Selector创建之初均为空</p>
*
* Selection操作分为三步</p>
* 1. cancelled-key集合中的key将会被从所有key集合中删除,其通道将会被注销.这步执行结束后会导致cancelled-key集合为空</br>
* 2. selection操作开始时,底层操作系统将会返回所有channel当前可执行的操作的key,对于任一符合条件的channel:
* </t>1. 若key不是selected-key的元素,将被加入其中。其可执行的操作集合会被更新,并且通知channel,该集合中之前的所有记录会被丢弃。</br>
* </t>2. 若是selected-key的元素,可执行操作将被添加到集合中,集合中之前的记录保留.</br>
* 3. 若在第二步执行过程中key被加入cancelled-key中,则他们将会按照第一步所述操作处理</br>
*
* @author luojiahu
*
*/
public abstract class Selector implements Closeable { /**
* 返回key集合
* @return
*/
public abstract Set<SelectionKey> keys(); /**
* 返回selected key集合
* @return
*/
public abstract Set<SelectionKey> selectedKeys(); /**
* 阻塞selection timeout时间。不保证实时返回
* @param timeout
* @return
* @throws IOException
*/
public abstract int select(long timeout) throws IOException; /**
* 阻塞selection
* @return
* @throws IOException
*/
public abstract int select() throws IOException; /**
* 非阻塞selection。若从上次selection结束到这次开始没有channel变为selectable则返回0
* @return
* @throws IOException
*/
public abstract int selectNow() throws IOException;
}

  Selector 和 SelectableChannel间通过SelectionKey表示注册关系:

/**
* 表示selectable channel在selector上的注册关系</p>
*
* 维护两个operation set: 1. interest set 2. ready set</p>
*
* 线程安全</p>
*
* 支持attachment</p>
* @author luojiahu
*
*/
public abstract class SelectionKey { /**
* 返回对应的channel
* @return
*/
public abstract SelectableChannel channel(); /**
* 返回对应的Selector
* @return
*/
public abstract Selector selector(); /**
* 解除channel和register间的注册关系
*/
public abstract void cancel(); /**
* 返回interest operation set
* @return
*/
public abstract int interestOps(); /**
* 设置interest operation set
* @param ops
* @return
*/
public abstract SelectionKey interestOps(int ops); /**
* 返回 ready operation set
* @return
*/
public abstract int readyOps(); /**
* 读,写,连接,接受连接
*/
public static final int OP_READ = 1 << 0;
public static final int OP_WRITE = 1 << 2;
public static final int OP_CONNECT = 1 << 3;
public static final int OP_ACCEPT = 1 << 4; /**
* 是否可读
* @return
*/
public final boolean isReadable() {
return (readyOps() & OP_READ) != 0;
}
}

  SelectorProvider

  SelectorProvider用于提供selector或者 selectable channel, 其本身持有一个SelectorProvider类型的对象。在一个JVM中SelectorProvider只有一个实例,通过本身的provider方法返回JVM唯一的SelectorProvider。

Java NIO 之 Selector的更多相关文章

  1. Java NIO类库Selector机制解析(下)

    五.  迷惑不解 : 为什么要自己消耗资源? 令人不解的是为什么我们的Java的New I/O要设计成这个样子?如果说老的I/O不能多路复用,如下图所示,要开N多的线程去挨个侦听每一个Channel ...

  2. Java NIO类库Selector机制解析(上)

    一.  前言 自从J2SE 1.4版本以来,JDK发布了全新的I/O类库,简称NIO,其不但引入了全新的高效的I/O机制,同时,也引入了多路复用的异步模式.NIO的包中主要包含了这样几种抽象数据类型: ...

  3. Java NIO 选择器(Selector)的内部实现(poll epoll)

    http://blog.csdn.net/hsuxu/article/details/9876983 之前强调这么多关于linux内核的poll及epoll,无非是想让大家先有个认识: Java NI ...

  4. Java NIO类库Selector机制解析--转

    一.  前言 自从J2SE 1.4版本以来,JDK发布了全新的I/O类库,简称NIO,其不但引入了全新的高效的I/O机制,同时,也引入了多路复用的异步模式.NIO的包中主要包含了这样几种抽象数据类型: ...

  5. Java NIO之Selector(选择器)

    历史回顾: Java NIO 概览 Java NIO 之 Buffer(缓冲区) Java NIO 之 Channel(通道) 其他高赞文章: 面试中关于Redis的问题看这篇就够了 一文轻松搞懂re ...

  6. Java NIO 选择器(Selector)的内部实现(poll epoll)(转)

    转自:http://blog.csdn.net/hsuxu/article/details/9876983 之前强调这么多关于linux内核的poll及epoll,无非是想让大家先有个认识: Java ...

  7. Java NIO之Selector

    选择器是JavaNIO重磅推出的一个概念:在旧有的系统中为了跟踪多端口消息,需要为每一个端口配备一个线程做监听:但是有了selector就不需要了,一个Selector可以管理一众渠道(channel ...

  8. Netty快速入门(05)Java NIO 介绍-Selector

    Java NIO Selector Selector是Java NIO中的一个组件,用于检查一个或多个NIO Channel的状态是否处于可读.可写.如此可以实现单线程管理多个channels,也就是 ...

  9. Java NIO教程 Selector

    这次我们开讲非阻塞I/O中的Selector,它需要配合非阻塞的TCP和UDP来使用.首先我们先简单讲一下TCP和UDP的非阻塞通道. 非阻塞I/O通道 在上代码前我们先讲解一些最基本的知识.TCP和 ...

  10. JAVA NIO 之 Selector 组件

    NIO 重要功能就是实现多路复用.Selector是SelectableChannel对象的多路复用器.一些基础知识: 选择器(Selector):选择器类管理着一个被注册的通道集合的信息和它们的就绪 ...

随机推荐

  1. 【转】qlv文件如何转换成mp4 怎样把下载好的qlv格式视频转换成MP4格式

    狸窝  复制  收藏  保存到桌面  快速找教程方案  反馈需求  社会主义核心价值观  客服QQ41442901   马上注册 升级VIP   对于视频文件之间的转换问题,我也已经是无力吐槽了,每个 ...

  2. jdk1.8新特性 : 接口中可以有普通方法(非静态方法)和静态方法 , 颠覆了之前我的理解 : 接口中只能有共有常量和抽象方法的概念,后面必须要加一句jdk1.7和1..7之前

    看到jdk某些接口中存在default方法,于是... http://shaomeng95.iteye.com/blog/998820    为什么接口只能是公有常量? public interfac ...

  3. mmap函数实现

    转自:https://www.cnblogs.com/huxiao-tee/p/4660352.htmlmmap是一种内存映射文件的方法,即将一个文件或者其它对象映射到进程的地址空间,实现文件磁盘地址 ...

  4. vs2012 .net4.0 nuget 导入NHibernate4.0版本

    问题描述: 最近弄一个项目,打算使用NHibernate,本人使用的VS2012,项目用的是.NET 4.0.在使用Nuget安装引用的时候,发现安装失败,提示如下图: 意思是当前安装的NHibern ...

  5. vue-router 组件复用问题

    组件系统是Vue的一个重要组成部分,它可以将一个复杂的页面抽象分解成许多小型.独立.可复用的组件,通过组合组件来组成应用程序,结合vue-router的路由功能将各个组件映射到相应的路由上,通过路由的 ...

  6. AtCoder Grand Contest 017

    noi前橙名计划失败.全程搞C而gg…… A - Biscuits 题意:背包,求价值为奇/偶的方案数. #include<cstdio> #include<queue> #i ...

  7. HDU 1000 A + B Problem(指针版)

    A + B Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) To ...

  8. HDU--2011

    多项式求和 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  9. 数据结构课程设计四则运算表达式求值(C语言版)

    本系统为四则运算表达式求值系统,用于带小括号的一定范围内正负数的四则运算标准(中缀)表达式的求值.注意事项:    1.请保证输入的四则表达式的合法性.输入的中缀表达式中只能含有英文符号"+ ...

  10. POJ 3829 Seat taking up is tough(——只是题目很长的模拟)

    题目链接: http://poj.org/problem?id=3829 题意描述: 输入矩阵的大小n和m,以及来占位置的人数k 输入n*m的教室座位矩阵,每个值表示该座位的满意度 输入每个人来占位置 ...