首页 > 后端开发 > C++ > `boost::asio::io_service::run()` 何时阻塞?

`boost::asio::io_service::run()` 何时阻塞?

Linda Hamilton
发布: 2024-11-11 12:17:03
原创
511 人浏览过

When Does `boost::asio::io_service::run()` Block?

boost::asio::io_service何时运行阻塞/解除阻塞

io_service::run()的阻塞行为源于它对工作和处理程序的处理。 它一直处于阻塞状态,直到:

  • 所有工作已完成
  • 没有更多处理程序可供执行
  • io_service 已停止通过 stop()

破译短语“没有更多处理程序要分派”

当 io_service::run() 阻塞直到“没有更多处理程序要分派”时,它表示没有注册回调形式的未完成任务。

示例代码中的行为

示例 3a:阻塞

在第一个示例 (3a) 中,io_service 阻塞在 run() 内,直到所有三个已发布的斐波那契计算处理程序都已执行。

详细执行流程:

  1. 创建 io_service::work 是为了防止 run() 立即返回。
  2. 启动工作线程来运行 io_service 循环。
  3. 发布斐波那契计算的处理程序。
  4. io_service::work 被重置,允许 run() 退出。
  5. 工作线程加入,指示任务完成。

客户端代码:异步但有效同步

客户端代码似乎使用异步 I/O (async_receive),但它有效地同步运行:

执行流程:

  1. async_receive() 启动异步操作。
  2. io_service::run() 阻塞,直到操作完成或出现错误发生。
  3. 控制权返回到调用线程,并且执行处理程序。

同步对应:

等效的同步操作将是:

boost::asio::error_code error;
std::size_t bytes = socket.receive(buffer, error);
// Execute handler with error and bytes
登录后复制

一般指南:分离同步和异步操作

混合同步和异步操作会带来复杂性。考虑避免这种做法。 Boost.Asio 文档提供了有关异步编程优势的宝贵见解。

以上是`boost::asio::io_service::run()` 何时阻塞?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板