文档章节

简简单单网络NIO

ulpyuoo
 ulpyuoo
发布于 2015/04/22 15:07
字数 330
阅读 8
收藏 0

Socket通信模型简化下来很简单,主要有建立连接、维护连接、读、写。NIO作为基于事件模型实现,这些职责都以事件的形式表达,所以NIO关注的事件有:  

SelectionKey.OP_ACCEPT
SelectionKey.OP_CONNECT
SelectionKey.OP_READ
SelectionKey.OP_WRITE

每一个键表达了与之对应操作相关的一类事件。

要监听事件,则必须有注册监听与接收通知的地方,NIO的实现不同于平时见到的Listener模式,它是通过向Selector(轮询器)注册,通过遍历selector.selectedKeys()来获取事件通知。

注册:

serverChannel.register(selector, SelectionKey.OP_ACCEPT);

获取通知:

    while (true) {  
        //当注册的事件到达时,方法返回;否则,该方法会一直阻塞  
        selector.select();  
        // 获得selector中选中的项的迭代器,选中的项为注册的事件  
        Iterator ite = this.selector.selectedKeys().iterator();  
        while (ite.hasNext()) {  
            SelectionKey key = (SelectionKey) ite.next();  
            // do some thing
        }
    }

通过SelectionKey可以判断事件的类型,进行事件处理,也可以获取Channel进行读写数据。

那么selector怎么得来呢?见代码:

selector = Selector.open();

最初始用于注册监听的Channel:

服务端:

ServerSocketChannel serverChannel = ServerSocketChannel.open(); 
serverChannel.configureBlocking(false);
serverChannel.socket().bind(new InetSocketAddress(port));

客户端:

SocketChannel channel = SocketChannel.open();
channel.configureBlocking(false); 
channel.connect(new InetSocketAddress(ip,port));

大概的结构就介绍完了,网上找个例子好好看看吧。

© 著作权归作者所有

共有 人打赏支持
ulpyuoo
粉丝 0
博文 6
码字总数 1951
作品 0
Java IO/NIO学习总结

下面是自己学习整理Java IO/NIO的总结,期间浏览了网上很多优秀的总结分析文章,一并贴在这里供大家学习参考。IO的知识点学习大概分为以下几个部分: 概念理解 熟悉Java IO API 熟悉Java NI...

isam
2016/03/22
208
0
从Jetty、Tomcat和Mina中提炼NIO构架网络服务器的经典模式(一)

从Jetty、Tomcat和Mina中提炼NIO构架网络服务器的经典模式(一) 收藏 如何正确使用NIO来构架网络服务器一直是最近思考的一个问题,于是乎分析了一下Jetty、Tomcat和Mina有关NIO的源码,发现...

光石头
2011/02/20
0
0
JAVA NIO non-blocking模式实现高并发服务器

Java自1.4以后,加入了新IO特性,NIO. 号称new IO. NIO带来了non-blocking特性. 这篇文章主要讲的是如何使用NIO的网络新特性,来构建高性能非阻塞并发服务器. 文章基于个人理解,我也来搞搞NIO.,...

Mr&Cheng
2013/01/30
0
1
为什么选择Netty作为基础通信组件?

以下内容根据网上资料和自己整理总结而成 一、什么是Netty? Netty是一个高性能 事件驱动、异步非堵塞的IO(NIO)Java开源框架,Jboss提供,用于建立TCP等底层的连接,基于Netty可以建立高性能...

ZhakyMing
2016/10/19
5.5K
23
JAVA NIO non-blocking模式实现高并发服务器

Java自1.4以后,加入了新IO特性,NIO. 号称new IO. NIO带来了non-blocking特性. 这篇文章主要讲的是如何使用NIO的网络新特性,来构建高性能非阻塞并发服务器. 文章基于个人理解,我也来搞搞NIO.,...

xpbug
2013/01/10
0
4

没有更多内容

加载失败,请刷新页面

加载更多

下一页

OSChina 周三乱弹 —— 公司女同事约我

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @莱布妮子:分享水木年华的单曲《蝴蝶花(2002年大提琴版)》 《蝴蝶花(2002年大提琴版)》- 水木年华 手机党少年们想听歌,请使劲儿戳(这里) ...

小小编辑
8分钟前
28
4
Linux环境搭建 | VMware下共享文件夹的实现

在进行程序开发的过程中,我们经常要在主机与虚拟机之间传递文件,比如说,源代码位于虚拟机,而在主机下阅读或修改源代码,这里就需要使用到 「共享文件」 这个机制了。本文介绍了两种共享文...

良许Linux
今天
5
0
JUC锁框架——AQS源码分析

JUC锁介绍 Java的并发框架JUC(java.util.concurrent)中锁是最重要的一个工具。因为锁,才能实现正确的并发访问。而AbstractQueuedSynchronizer(AQS)是一个用来构建锁和同步器的框架,使用A...

长头发-dawn
今天
3
0
docker中安装了RabbitMQ后无法访问其Web管理页面

在官网找了"$ docker run -d --hostname my-rabbit --name some-rabbit -p 8080:15672 rabbitmq:3-management"这条安装命令,在docker上安装了RabbitMQ,,结果输入http://localhost:8080并不......

钟然千落
今天
4
1
spring-cloud | 分布式session共享

写在前面的话 各位小伙伴,你们有福了,这一节不仅教大家怎么实现分布式session的问题,还用kotlin开发,喜欢kotlin的小伙伴是不是很开心! 以前在写Android的时候,就对客户端请求有一定的认...

冯文议
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部