select - 等待流事件
2023-11-01
这个模块实现了相应 CPython 模块的一个子集,如下所述。有关更多信息,请参阅原始CPython文档: select
该模块提供了有效等待多个 :term:stream
(选择可用于操作的流)上的事件的功能。
函数
uselect.poll()
创建轮询实例。
uselect.select(rlist, wlist, xlist[, timeout])
监控对象何时可读或可写,一旦监控的对象状态改变,返回结果(阻塞线程)。
这个函数是为了兼容,效率不高,推荐用 poll 函数。
rlist
:等待读就绪的文件描述符数组wlist
:等待写就绪的文件描述符数组xlist
:等待异常的数组timeout
:等待时间(单位:秒)
类 Poll
方法
poll.register(obj, flag)
注册一个用以监控的对象,并设置被监控对象的监控标志位flag。
obj
:被监控的对象flag
:被监控的标志select.POLLIN
- 读取可用数据select.POLLOUT
- 写入更多数据select.POLLERR
- 发生错误select.POLLHUP
- 流结束/连接终止检测
flag
默认为 select.POLLIN | select.POLLOUT
.
poll.unregister(obj)
解除监控的对象obj
的注册。
poll.modify(obj, flag)
修改已注册的对象 obj
监控标志 flag
。
poll.poll([timeout])
等待至少一个注册对象准备就绪。返回(obj
, event
, …)元组的列表, event
元素指定使用流发生的事件,
并且是 select.POLL*
上述常量的组合。在tuple中可能还有其他元素,具体取决于平台和版本,因此不要认为它的大小是2.
如果超时,返回一个空列表。
超时是毫秒。
与CPython区别
如上所述,返回的元组可能包括多于2个元素。
poll.ipoll([timeout])
与 poll.poll
类似,但是返回一个产生被调用函数所有元组的迭代器。该函数提供高效的、无位置的在流中进行轮询的方法。
与CPython区别
该函数是MicroPython的扩展。