select – 等待流事件¶
这个模块实现了相应 CPython 模块的一个子集,如下所述。有关更多信息,请参阅原始CPython文档: select
该模块提供了有效等待多个 stream (选择可用于操作的流)上的事件的功能。
函数¶
-
select.poll()¶
创建轮询实例。
-
select.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. 如果超时,返回一个空列表。超时是毫秒。
Difference to CPython
Tuples returned may contain more than 2 elements as described above.
-
poll.ipoll([timeout])¶ 与
poll.poll()类似,但是返回一个产生被调用函数所有元组的迭代器。该函数提供高效的、无位置的在流中进行轮询的方法。与CPython区别
该函数是MicroPython的扩展。