boost::asio::io_service和io_service::work和boost::thread_group配合使用

boost::asio::io_service和io_service::work和boost::thread_group配合使用

[cpp]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. //注释中的Page是指:Boost程序库完全开发指南(第三版)  
  2. #include <iostream>  
  3. //Page542: 在头文件<boost/asio.hpp>前定义此宏,它就会向标准流cerr输出运行日志。  
  4. //#define BOOST_ASIO_ENABLE_HANDLER_TRACKING  
  5. #include <boost/asio.hpp>  
  6.   
  7. #include <boost/thread.hpp>    
  8. long boost_thread_id_to_long(boost::thread::id id)  
  9. {  
  10.     std::stringstream ss; ss << id;  
  11.     return strtol(std::string(ss.str()).c_str(), (char**)NULL, 16);  
  12. }  
  13.   
  14. #include <boost/date_time/posix_time/posix_time.hpp>  
  15. std::string local_time_to_simple_string()  
  16. {  
  17.     boost::posix_time::ptime ptm = boost::posix_time::microsec_clock::local_time();  
  18.     return boost::posix_time::to_simple_string(ptm);  
  19. }  
  20.   
  21. #include <boost/format.hpp>  
  22. std::string completion_handler_fun(float f, std::string str)  
  23. {  
  24.     str = (boost::format("%|s|, thread_id=%|ld|, f=%|.3f|, str=%|s|")  
  25.         % local_time_to_simple_string()  
  26.         % boost_thread_id_to_long(boost::this_thread::get_id())  
  27.         % f % str.c_str()).str();  
  28.     std::cout << str << std::endl;  
  29.     return str;  
  30. }  
  31.   
  32. int main1()  
  33. {  
  34.     boost::asio::io_service io;  
  35.     io.post(boost::bind(completion_handler_fun, 3.141592653f, "111"));  
  36.     io.post(boost::bind(completion_handler_fun, 3.141592653f, "222"));  
  37.     std::cout << "sleep some seconds before run" << std::endl;  
  38.     boost::this_thread::sleep_for(boost::chrono::seconds(3));  
  39.     io.run();  
  40.     std::cout << "sleep some seconds after  run" << std::endl;  
  41.     boost::this_thread::sleep_for(boost::chrono::seconds(3));  
  42.     return 0;  
  43.     //在这个程序中,主线程提供了io_service::run的上下文。也可以创建一个线程,然后在这个线程里执行run函数。  
  44.     //当run开始后,就执行所有的handler,如果io_service里面没有可执行的handler了,就退出run函数了。  
  45. }  
  46.   
  47. int main2()  
  48. {  
  49.     boost::asio::io_service io;  
  50.     //请阅读Page540的io_service::work的描述。  
  51.     //io_service::work会让io_service::run始终有事可做,所以不会退出run函数。  
  52.     boost::asio::io_service::work wk(io);  
  53.     io.post(boost::bind(completion_handler_fun, 3.141592653f, "111"));  
  54.     io.post(boost::bind(completion_handler_fun, 3.141592653f, "222"));  
  55.     std::cout << "sleep some seconds before run" << std::endl;  
  56.     boost::this_thread::sleep_for(boost::chrono::seconds(3));  
  57.     io.run();  
  58.     //有io_service::work的存在,所以,即时没有可执行的handler了,也不会退出run函数。  
  59.     std::cout << "io_service::run is end and will exit." << std::endl;  
  60.     return 0;  
  61. }  
  62.   
  63. int main3()  
  64. {  
  65.     boost::asio::io_service io;  
  66.     //事先在io_service里面放了100个要执行的handler。  
  67.     for (int i = 0; i < 100; ++i)  
  68.     {  
  69.         std::stringstream ss; ss << i;  
  70.         io.post(boost::bind(completion_handler_fun, 3.141592653f, std::string(ss.str())));  
  71.     }  
  72.     boost::thread_group th_gp;  
  73.     //线程组创建3个线程,同时处理这100个handler。  
  74.     for (int i = 0; i < 3; ++i)  
  75.     {  
  76.         boost::thread* th_ptr = th_gp.create_thread(boost::bind(&boost::asio::io_service::run, boost::ref(io)));  
  77.         std::cout << "thread_group, thread_id=" << boost_thread_id_to_long(th_ptr->get_id()) << std::endl;  
  78.     }  
  79.     //这3个线程可能同时往屏幕上输出,所以屏幕可能会乱。  
  80.     //执行完handler后,run函数退出,线程退出,thread_group的join_all会执行完毕。  
  81.     th_gp.join_all();  
  82.     std::cout << "will exit" << std::endl;  
  83.     boost::this_thread::sleep_for(boost::chrono::seconds(3));  
  84.     return 0;  
  85. }  
  86.   
  87. int main()  
  88. {  
  89.     boost::asio::io_service io;  
  90.     //io_service::work阻止了io_service的run函数退出,所以thread_group的join_all函数会一直阻塞在那里。  
  91.     boost::asio::io_service::work wk(io);  
  92.     boost::thread_group th_gp;  
  93.     for (int i = 0; i < 3; ++i)  
  94.     {  
  95.         boost::system::error_code error;  
  96.         boost::thread* th_ptr = th_gp.create_thread(boost::bind(&boost::asio::io_service::run, boost::ref(io), error));  
  97.         std::cout << "thread_group, thread_id=" << boost_thread_id_to_long(th_ptr->get_id()) << std::endl;  
  98.     }  
  99.     io.post(boost::bind(completion_handler_fun, 3.141592653f, "xxx"));  
  100.     th_gp.join_all();  
  101.     std::cout << "will exit" << std::endl;  
  102.     boost::this_thread::sleep_for(boost::chrono::seconds(3));  
  103.     return 0;  
  104. }  
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`boost::asio::io_service`是Boost库中的一个核心类,用于提供异步I/O操作的事件循环机制。它是实现异步网络编程的基础,可用于处理各种网络通信任务。 `boost::asio::io_service`的主要作用是管理和调度异步操作。它负责处理事件循环,监视和分发I/O事件,以及执行注册的回调函数。通过使用`io_service`对象,可以实现非阻塞式的异步I/O编程,提高程序的并发性和响应性。 以下是`boost::asio::io_service`类的常见用法示例: ```cpp #include <boost/asio.hpp> void handleRead(const boost::system::error_code& error, std::size_t bytes_transferred) { if (!error) { // 处理读取数据的回调逻辑 } else { // 处理错误情况 } } int main() { boost::asio::io_service io_service; // 创建一个socket对象 boost::asio::ip::tcp::socket socket(io_service); // 连接到服务器 socket.connect(endpoint); // 异步读取数据 boost::asio::async_read(socket, boost::asio::buffer(buffer), handleRead); // 开始事件循环 io_service.run(); return 0; } ``` 在上述示例中,首先创建了一个`io_service`对象,然后创建了一个TCP socket对象,并使用`io_service`对象进行异步读取操作。在`async_read`函数中,指定了一个回调函数`handleRead`,用于处理读取数据完成后的回调逻辑。 最后,通过调用`io_service`的`run()`函数启动事件循环,使程序进入等待事件的状态。在事件循环中,`io_service`会不断地监视和分发I/O事件,并执行注册的回调函数。 使用`boost::asio::io_service`,可以方便地实现异步的网络编程,处理各种I/O操作,如读取、写入、连接、接收等。它提供了高度灵活和可扩展的方式来构建异步应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值