一、Selectors模块

  它具有根据平台选出最佳的IO多路机制,比如在win的系统上他默认的是select模式而在linux上它默认的epoll,建议使用selectors。

  常用共分为三种:select、poll、epoll

二、用法

  selectors server

# -*- coding: UTF-8 -*-

import selectors
import socket # 生成一个selectors对象
# 根据平台选择最佳的IO多路机制,比如linux就会选择epoll
sel = selectors.DefaultSelector() def accept(sock, mask): # 参数scok就是while循环中的key.fileobj
conn, addr = sock.accept() # 相当于select 的readable 列表
print('accepted', conn, 'from', addr, '****', mask)
conn.setblocking(False)
sel.register(conn, selectors.EVENT_READ, read) # 新连接注册read回调函数 def read(conn, mask):
data = conn.recv(1024)
if data:
print('echoing', repr(data), 'to', conn)
conn.send(data)
else: # 没数据代表断了
print('closing', conn)
sel.unregister(conn)
conn.close() server = socket.socket()
server.bind(('localhost', 9999))
server.listen()
server.setblocking(False)
# 注册事件,将server注册到sel中,让sel去监听
# accept 只要来一个新连接,就调用这个函数
sel.register(server, selectors.EVENT_READ, accept) while True:
events = sel.select()
# 默认是阻塞的,有活动连接时返回活动的连接列表,event就是这活动列表
# select(), 可能是select/epoll 看系统支持
print(events) for key, mask in events:
callback = key.data # 相当于调用 accept, callback获取了函数地址
callback(key.fileobj, mask) # key.fileobj 是文件句柄

  下面开始强行解释了。。。。。

  2.1 生成一个selectors对象 

sel = selectors.DefaultSelector() 

 根据平台选择最佳的IO多路机制,比如linux就会选择epoll,windows不支持epoll,所以会用select。

  2.2 监听server 

server = socket.socket()
server.bind(('localhost', 9999))
server.listen()
server.setblocking(False)

  2.3 注册事件 

sel.register(server, selectors.EVENT_READ, accept)  

  将server注册到sel中,让sel去监听,只要有一个新连接进来,就调用accept函数

  2.4 循环事件  

while True:
events = sel.select()
print(events) for key, mask in events:
callback = key.data
callback(key.fileobj, mask)

  循环接收连接和数据,默认是阻塞的。只要有活动连接进来,就返回一个列表events。同时sel.select()可根据系统自动选定epoll/select模式。

  events: 

[(SelectorKey(fileobj=<socket.socket fd=268, family=AddressFamily.AF_INET,
type=SocketKind.SOCK_STREAM, proto=0, laddr=('127.0.0.1', 9999)>,
fd=268, events=1, data=<function accept at 0x000002575F87E488>), 1)]

  callback = key.data,其实就是accept函数的内存地址

   callback() 就是调用accept函数。

  key.fileobj ,mask分别是accept函数的两个参数。fileobj很好理解,就是监听的socket的文件句柄。而mask指的是事件类型,EVENT_READ 是 1 ,EVENT_WRITE 是 2。

  2.5 accept函数

  accept函数的功能类似于 select中的 readable列表,当有一个连接进来时,不立刻接收或发生数据,而是放到一个队列中,再从队列中获取/返回数据。accept函数将监听的连接注册到一个事件中,调用read函数,数据的收发就在read函数中进行。

  有数据进来时,events: 

[(SelectorKey(fileobj=<socket.socket fd=352, family=AddressFamily.AF_INET,
type=SocketKind.SOCK_STREAM, proto=0, laddr=('127.0.0.1', 9999),
raddr=('127.0.0.1', 50853)>, fd=352, events=1, data=<function read at 0x000002575F87EA60>), 1)] echoing b'sdfsdf' to <socket.socket fd=352, family=AddressFamily.AF_INET,
type=SocketKind.SOCK_STREAM, proto=0, laddr=('127.0.0.1', 9999), raddr=('127.0.0.1', 50853)>

  accept函数执行完毕后,对一个连接的监听建立。如果这个连接再发生数据到server端,events中的fileobj就会变成 这个scoket连接的信息,key.data就是read函数的内存地址:

  此时,callback(key.fileobj, mask) = read(key.fileobj, mask)

  

  2.6 read函数

  对监听的连接收发数据,断开连接等处理。

 

selectors的更多相关文章

  1. DOM扩展-Selectors API(选择符 API)、元素遍历

    DOM扩展 对DOM的两个主要扩展是SelectorsAPI(选择符API)和HTML5 SelectorsAPI(选择符API)是由W3C发起制定的一个标准,致力于浏览器原生支持CSS查询,Sele ...

  2. BeautifulSoup高级应用 之 CSS selectors /CSS 选择器

    BeautifulSoup支持最常用的CSS selectors,这是将字符串转化为Tag对象或者BeautifulSoup自身的.select()方法. 本篇所使用的html为: html_doc ...

  3. CSS 笔记六(Image/Attribute Selectors)

    Image Opacity / Transparency The CSS opacity property is a part of the CSS3 recommendation. Example ...

  4. CSS 笔记一(Selectors/ Backgrounds/ Borders/ Margins/ Padding/ Height and Width)

    Selectors/ Backgrounds/ Borders/ Margins/ Padding/ Height and Width CSS Introduction: CSS stands for ...

  5. DOM扩展之Selectors API

    jQuery的核心就是通过CSS选择符查询DOM文档取得元素的引用,从而抛开了getElementById()和getElementsByTagName(). Selectors API致力于让浏览器 ...

  6. 转:SELENIUM TIPS: CSS SELECTORS

    This page will show you some CSS rules and pseudo-classes that will help you move your XPATH locator ...

  7. selectors实现高并发

    1. 下面的例子,客户端给服务端发送消息,服务端把消息返回 server #!/usr/bin/env python import selectors import socket import tim ...

  8. 【CSS3】Advanced3:Universal, Child, and Adjacent Selectors

    1.Universal selectors eg:#target*{ } 2.Child selectors < something immediately nested within some ...

  9. 【CSS】Intermediate1:Class and ID Selectors

    1.html tag = css selector 2.Define your own selectors in the form of class and ID selectors 3. .clas ...

  10. 【CSS】Beginner2:Selectors, Properties, and Values

    1.Whereas HTML has tags,CSS has selectors.   2.Selector{ properties:value; properties2:value2; }   3 ...

随机推荐

  1. Github三次学习

    作者声明:本文参照aicoder.com马伦老师的文档,根据自己的学习情况而做的笔记,仅供交流学习. Git入门到高级教程 为什么要进行项目文件的版本管理 代码备份和恢复 团队开发和协作流程 项目分支 ...

  2. Java访问控制

    转自:菜鸟教程

  3. Alpha发布用户使用报告

    此作业要求参见:[https://edu.cnblogs.com/campus/nenu/2018fall/homework/2325] 组名:可以低头,但没必要 组长:付佳 组员:张俊余 李文涛 孙 ...

  4. git中的重要指令

    git命令 任何操作都需要以 git 命令为开头 本地操作: git init 初始化一个本地仓库 新建为 master主分支 git status 查看当前分支状态 git add <文件名& ...

  5. 王者荣耀交流协会-小组互评Alpha版本

    小组分工如下: 1.探路者---贪吃蛇(测评人:王玉玲) 链接:http://www.cnblogs.com/WYLFZ/p/7805520.html    http://www.cnblogs.co ...

  6. 04慕课网《进击Node.js基础(一)》HTTP讲解

    HTTP:通信协议 流程概述: http客户端发起请求,创建端口默认8080 http服务器在端口监听客户端请求 http服务器向客户端返回状态和内容 稍微详细解析: 1.域名解析:浏览器搜素自身的D ...

  7. myeclipse生成类的帮助文档

    http://blog.csdn.net/tabactivity/article/details/11807233

  8. IT小小鸟的读后感

    在我经历了半个学期的大学生活后,我依然不清楚我现在所学的专业有什么用或者说该怎么学.直到我阅读了<我是一只IT小小鸟>这篇文章之后.我才对我所将来或许要从事的IT事业有了些许的了解. 在观 ...

  9. DB2 9.5 数据库分区管理及应用实践

    DB2 数据库分区是 DB2 企业版 DPF(Data Partitioning Feature)选件提供的,它主要用来为大规模数据处理.高并发数据访问提供支持.DB2 数据库分区采用 Share-n ...

  10. PHP中parent关键词

    parent关键词 parent表示“父母”的意思,在面向对象语法中,代表“父类” ——本质上就是代表父类这个“类”,而不是父类的“对象”: 其使用方式为: parent::属性或方法: //通常是静 ...