10、boost asio 教程---阻止 `io_context::run` 返回

`io_context::run` 运行直到所有计划的任务都完成。然后,`io_context::run` 将返回,并且调用线程将解除阻塞:

boost::asio::io_context io_context;
// 安排一些任务
io_context.run();
std::cout << "任务完成!继续执行\n";

然而,有时您可能需要无论是否有要执行的任务都保持它运行。到目前为止,我们已经审查过的服务器始终在执行 `async_accept`,因此它们始终至少有一个已计划的任务,所以我们实际上不需要以这种方式保持它们运行。但是客户端不执行 `async_accept`,这对于它在某个时候没有计划的任务是正常的。要防止 `io_context::run` 返回,您应该使用 `boost::asio::executor_work_guard`(以前的 `io_context::work`,目前已弃用)类实例。它的名称太长了,因此让我们立即给它起一个别名:

using work_guard_type = boost::asio::executor_work_guard<boost::asio::io_context::executor_type>;

boost::asio::io_context io_context;
work_guard_type work_guard(io_context.get_executor());
// 安排一些任务或不安排
io_context.run();
std::cout << "对不起,我们永远不会到达这里!\n";

猜你喜欢

转载自blog.csdn.net/Knowledgebase/article/details/132861545
今日推荐