select -- 高效地等待I/O

这个模块实现了相应 CPython 模块的一个子集,如下所述。有关更多信息,请参阅原始CPython文档: select

该模块提供了有效等待多个事件 ``streams``(准备好操作的选择流)的功能。

函数

select.poll()

创建Poll类的实例。

select.select(rlist, wlist, xlist[, timeout])

监控对象何时可读或可写,一旦监控的对象状态改变,返回结果(阻塞线程)。 这个函数是为了兼容,效率不高,推荐用 poll 函数。

  • rlist:等待读就绪的文件描述符数组

  • wlist:等待写就绪的文件描述符数组

  • xlist:等待异常的数组

  • timeout:等待时间(单位:秒)

类 Poll

方法

poll.register(obj[, eventmask])

注册一个用以监控的对象, eventmask 是逻辑OR:stream

  • obj :被监控的对象

    • select.POLLIN - 读取可用数据

    • select.POLLOUT - 写入更多数据

    • select.POLLERR - 发生错误

    • select.POLLHUP - 流结束/连接终止检测

    需要注意的是像标志 uselect.POLLHUPuselect.POLLERR 是不是为输入 eventmask 有效(这些是从返回不请自来的事件poll(),无论他们是否被要求)。 这个语义是按POSIX。

eventmask 默认为 select.POLLIN | select.POLLOUT.

可以多次为同一个 obj 调用此函数。连续调用将更新OBJ的 eventmask 到的值 eventmask`(即会表现为 ``modify()` )。

poll.unregister(obj)

从轮询中取消注册obj。

poll.modify(obj, eventmask)

修改已注册的对象 obj ,如果未注册obj,OSError 则会出现ENOENT错误。

poll.poll([timeout])

等待至少一个已注册的对象准备就绪或具有异常条件,可选的超时(以毫秒为单位)(如果 未指定超时 arg或-1,则没有超时)。

返回列表( obj, event, ...)的元组。元组中可能还有其他元素,具体取决于平台和版本,因此不要假设其大小为2.

event元素指定流发生的事件,并且是 uselect.POLL* 上述常量的组合。需要注意的是标志 uselect.POLLHUP ,并 uselect.POLLERR 可以在任何时候(即使不要求)返回的,必须采取相应的行动(从调查未注册并有可能关闭相应的流),否则所有的进一步调用 poll() 可以用这些标志设置立即返回再次为这个流。

如果超时,则返回空列表。

Difference to CPython

返回的元组可能包含超过2个元素,如上所述。

poll.ipoll([timeout])

poll.poll() 类似,但是返回一个产生被调用函数所有元组的迭代器。该函数提供高效的、无位置的在流中进行轮询的方法。

与CPython区别

该函数是MicroPython的扩展。