`
whao189
  • 浏览: 123103 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

创建非阻塞的Socket服务器<三>

阅读更多
上两篇文章我简单总结了NIO包中的class也提到了Buffer和Charset 说了他们的用途,
这次我们再来看看NIO中最重要的一个类Channel,之所以说它重要,并不是他自身的用途有多大
而是他的子类!很强大,SelectableChannel ReadableByteChannel WritableByteChannel 都是他的子类,就是因为这些类他很重要!我们来具体来看看(在Channel下不仅仅这几个类)

ReadableByteChannel  WritableByteChannel  可以看出了他们是相对的我这里就解释一个类那么另一个类我们就知道是做什么的了!

ReadableByteChannel 中有一个read 方法

read(ByteBuffer bb)

这个方法就是把数据读入到指定的bb 这个缓冲区中。他还有很多子类但是这里我们不详细讲解了

下面来看看SelectablChannel 他是一种支持阻塞和非阻塞模式的通道。那么我们怎么来设置通道是不是阻塞呢?这个方法就是
configureBlcoking(boolean b)

他另外的重要的方法 就是
register(Selector sel,int options)

那么这个方法的作用是什么呢?怎么解释呢?我是这样理解的不知道理解对不对?

register这个方法就是把通道注册到相对应的Selector对象中并为这个通道添加一个标示以表示能在下次接收到相应的Selector 的时候 能根据我添加的这个 标示 知道要发生什么事情!

看到这里你可能会疑惑到底 通道是怎么处理数据的呢?
是的,任何处理数据的方式都离不开 读和写操作。。但是在SelectableChannel 并没有这两个方法,而在他的子类中(SocketChannel),你可能注意到了 ServerSocketChannel也是他的子类,但是他没有,同样是子类为何一个定义了。。一个没有定义这个read 和write 方法呢?

这是当然的。。。一个父亲有多个儿子,他们的学历不同能力的东西也不同,因为 ServerSocketChannel 里面能够产生SocketChannel 。。所以 他就可以产生这个对象,以至于他也用于了 read 和write 方法。。。
说到这里 你是不是明白些了!

那么我们接下来看看Selector 。。。刚才已经提到了。他给我感觉就是一个监视器,同时关注 ServerSocketChannel 和SocketChannel,因此下一个对象(SelectKey)就产生了,他就是专门表示标示的那个类,这样 我们就能在处理数据的时候根据标示的不同而做出不同的业务逻辑处理了。。


看一下 我自己理解NIO处理的整个过程


[/img]
  • 大小: 63.4 KB
分享到:
评论

相关推荐

    完成端口(IOCP) 服务器源码

    1. 创建服务器socket, 并将socket设置为非阻塞模式 2. bind()绑定IP地此与端口 3. listen() 4. 创建IO完成端口,将socket绑定到IO完成端口上 5. 根据当前机器CPU个数创建工作者线程池 6. 使用AcceptEx()提前创建...

    tcp服务器客户端demo

    在程序启动时候创建一个工作模式的代理来区分是否启动服务器以及是阻塞方式还是非阻塞方式 在WorkModeProxy中根据配置决定使用Socket的类型,以及工作模式的类型 支持使用不同的socket,可以通过SocketFactory进行...

    python实现单线程多任务非阻塞TCP服务端

    创建服务器socket sock = socket(AF_INET, SOCK_STREAM) # 2.绑定主机和端口 addr = ('', 7788) # sock.bind(addr) # 3. 设置最大监听数目,并发 sock.listen(10) # 4. 设置成非阻塞 sock.setblocking(False) # 保存...

    (牛客网C++课程)Linux 高并发Web服务器项目实战(带定时检测代码)

    1. 线程池 + 非阻塞 socket + epoll + 事件处理的并发模型 2. 状态机解析HTTP请求 3. 心跳机制 4. 简易日志系统 主要内容: 1. 使用 socket 实现服务器和浏览器客户端的通信; 2. 用 epoll 事件检测技术实现 IO 多...

    Python实现的服务器示例小结【单进程、多进程、多线程、非阻塞式】

    本文实例讲述了Python实现的服务器。分享给大家供大家参考,具体如下: python – 单进程服务器 #coding=utf-8 from socket import * #创建套接字 serSocket = socket(AF_INET, SOCK_STREAM) #重复使用绑定信息 ...

    MFC网络编程之自制浏览器

    网络编程,当然要用到Windows Socket(套接字)技术。Socket相关的操作由一系列...因此,建议初学者学习编网络通信程序时,暂且不要用MFC提供的类,而先用Winsock2 API,这样有助于对异步、非阻塞Socket编程机制的理解。

    高性能IO模型浅析

    (2)同步非阻塞IO(Non-blocking IO):默认创建的socket都是阻塞的,非阻塞IO要求socket被设置为NONBLOCK。注意这里所说的NIO并非Java的NIO(New IO)库。 (3)IO多路复用(IO Multiplexing):即经典的Reactor...

    服务器概要设计说明.docx

    Windows下有五种非阻塞I/O模型:选择〔Select〕、异步选择〔WSAAsyncSelect〕、事件选择〔WSAEventSelect〕、重叠I/O〔Overlapped I/O〕和完成端服务器概要设计说明全文共5页,当前为第2页。服务器概要设计说明全文...

    Linux高性能服务器编程

    9.2 poll系统调用 9.3 epoll系列系统调用 9.3.1 内核事件表 9.3.2 epoll_wait函数 9.3.3 LT和ET模式 9.3.4 EPOLLONESHOT事件 9.4 三组IO复用函数的比较 9.5 IO复用的高级应用一:非阻塞connect 9.6 IO复用...

    Java网络编程(第三版)中文版.part11.rar

    第十二章 非阻塞I/O 391 一个示例客户端 392 一个示例服务器 396 缓冲区 402 通道 421 就绪选择 427 第十三章 UDP数据报和Socket 431 UDP协议 431 DatagramPacket类 433 DatagramSocket类 442 一些有用的...

    Java网络编程(第三版)中文版.part06.rar

    第十二章 非阻塞I/O 391 一个示例客户端 392 一个示例服务器 396 缓冲区 402 通道 421 就绪选择 427 第十三章 UDP数据报和Socket 431 UDP协议 431 DatagramPacket类 433 DatagramSocket类 442 一些有用的...

    Java网络编程(第三版)高清中文版.part01.rar

    第十二章 非阻塞I/O 391 一个示例客户端 392 一个示例服务器 396 缓冲区 402 通道 421 就绪选择 427 第十三章 UDP数据报和Socket 431 UDP协议 431 DatagramPacket类 433 DatagramSocket类 442 一些有用的...

    Java网络编程(第三版)中文版.part07.rar

    第十二章 非阻塞I/O 391 一个示例客户端 392 一个示例服务器 396 缓冲区 402 通道 421 就绪选择 427 第十三章 UDP数据报和Socket 431 UDP协议 431 DatagramPacket类 433 DatagramSocket类 442 一些有用的...

    Java网络编程(第三版)中文版.part09.rar

    第十二章 非阻塞I/O 391 一个示例客户端 392 一个示例服务器 396 缓冲区 402 通道 421 就绪选择 427 第十三章 UDP数据报和Socket 431 UDP协议 431 DatagramPacket类 433 DatagramSocket类 442 一些有用的...

    Java网络编程(第三版)中文版.part01.rar

    第十二章 非阻塞I/O 391 一个示例客户端 392 一个示例服务器 396 缓冲区 402 通道 421 就绪选择 427 第十三章 UDP数据报和Socket 431 UDP协议 431 DatagramPacket类 433 DatagramSocket类 442 一些有用的...

    Java网络编程(第三版)中文版.part03.rar

    第十二章 非阻塞I/O 391 一个示例客户端 392 一个示例服务器 396 缓冲区 402 通道 421 就绪选择 427 第十三章 UDP数据报和Socket 431 UDP协议 431 DatagramPacket类 433 DatagramSocket类 442 一些有用的...

    Java网络编程(第三版)中文版.part02.rar

    第十二章 非阻塞I/O 391 一个示例客户端 392 一个示例服务器 396 缓冲区 402 通道 421 就绪选择 427 第十三章 UDP数据报和Socket 431 UDP协议 431 DatagramPacket类 433 DatagramSocket类 442 一些有用的...

    Java网络编程(第三版)中文版.part04.rar

    第十二章 非阻塞I/O 391 一个示例客户端 392 一个示例服务器 396 缓冲区 402 通道 421 就绪选择 427 第十三章 UDP数据报和Socket 431 UDP协议 431 DatagramPacket类 433 DatagramSocket类 442 一些有用的...

    Java网络编程(第三版)中文版.part10.rar

    第十二章 非阻塞I/O 391 一个示例客户端 392 一个示例服务器 396 缓冲区 402 通道 421 就绪选择 427 第十三章 UDP数据报和Socket 431 UDP协议 431 DatagramPacket类 433 DatagramSocket类 442 一些有用的...

Global site tag (gtag.js) - Google Analytics