boost::io_service poll_one 和 run_one 有什么区别? [英] What's the difference between boost::io_service poll_one and run_one?

查看:25
本文介绍了boost::io_service poll_one 和 run_one 有什么区别?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

io_service::poll_one 运行 io_service 对象的事件处理循环执行一个就绪处理程序.

io_service::poll_one Run the io_service object's event processing loop to execute one ready handler.

对比

io_service::run_one 运行 io_service 对象的事件处理循环最多执行一个处理程序.

io_service::run_one Run the io_service object's event processing loop to execute at most one handler.

从那个解释看来, poll_one 可以执行多个处理程序?run_one 或 poll_one 是使用任何名为 run() 的线程还是仅使用调用 poll_one/run_one 的线程?

From that explanation it would seem poll_one could execute more than one handler? Does run_one or poll_one use any thread that's called run() or only the thread that calls poll_one/run_one?

ASIO 的文档非常稀少.

The documentation for ASIO is very sparse.

推荐答案

poll_one 将立即返回(非阻塞),以防没有事件要处理.

poll_one will return immediately (non-blocking) in case there is no event to process.

run_one 将阻塞调用线程,直到一个事件准备好处理.

run_one will block the calling thread until one event is ready to process.

您还可以查看一些文档这里

这篇关于boost::io_service poll_one 和 run_one 有什么区别?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆