12、boost asio 教程---多线程执行

到目前为止,我们所讨论的示例都在单个线程内运行。然而,在实际应用中,您希望充分利用Boost.Asio应用程序中的所有CPU核心。因此,我们应该学习如何在Boost.Asio中使用多线程进行操作。一如既往,让我们简洁明了地介绍一下:

namespace io = boost::asio;
using tcp = io::ip::tcp;
using error_code = boost::system::error_code;

有两种常见的方法可以实现多线程。在这节课中,我们将学习最简单的方法。让我们回顾一下单线程方法:

io::io_context io_context;
// Prepare things
io_context.run();

跳入多线程方法的最简单方式是在多个线程上运行具有相同io_context对象的io_context::run成员函数。

请注意,在包含Boost.Asio头文件之前,您应该定义BOOST_ASIO_NO_DEPRECATED宏。这将使您摆脱已弃用的Boost.Asio内容。在下面的示例中,我们需要摆脱的是通过引用接受error_code参数的已弃用io::io_context::run重载。在这种情况下,该重载会在创建线程的地方生成错误,因为io::io_context::run指针在这种情况下是模棱两可的。

#define BOOST_ASIO_NO_DEPRECATED
#include <boost/asio.hpp>
// ...

io::io_context io_context;
// Prepare things
std::vector<std::thread>

猜你喜欢

转载自blog.csdn.net/Knowledgebase/article/details/132984028