`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::execu