boost::asio::io_service::work类
来源:互联网 发布:ppt软件下载官方 编辑:程序博客网 时间:2024/06/06 02:47
出处:http://blog.csdn.net/pud_zha/article/details/37561011
work是一个很小的辅助类,只支持构造函数和析构函数。(还有一个get_io_service返回所关联的io_service)
构造一个work时,outstanding_work_+1,使得io.run在完成所有异步消息后判断outstanding_work_时不会为0,因此会继续调用GetQueuedCompletionStatus并阻塞在这个函数上。而析构函数中将其-1,并判断其是否为0,如果是,则post退出消息给GetQueuedCompletionStatus让其退出。
因此work如果析构,则io.run会在处理完所有消息之后正常退出。work如果不析构,则io.run会一直运行不退出。如果用户直接调用io.stop,则会让io.run立刻退出。
特别注意的是,work提供了一个拷贝构造函数,因此可以直接在任意地方使用。对于一个io_service来说,有多少个work实例关 联,则outstanding_work_就+1了多少次,只有关联到同一个io_service的work全被
析构之后,io.run才会在所有消息处 理结束之后正常退出。
0 0
- boost::asio::io_service::work类
- boost::asio::io_service::work类
- io_service类 boost asio
- boost.asio服务器使用io_service作为work pool
- boost.asio服务器使用io_service作为work pool
- boost.asio服务器使用io_service作为work pool
- boost.asio服务器使用io_service作为work pool
- boost::asio::io_service和io_service::work和boost::thread_group配合使用
- boost::asio::io_service和io_service::work和boost::thread_group配合使用
- boost::asio::Io_service
- boost::asio::Io_service
- boost::asio::Io_service
- boost::asio::Io_service
- boost::asio 之io_service
- boost::asio::Io_service strand
- boost::asio::io_service(之一)
- Boost::asio io_service
- Boost::asio io_service
- 最小重量和问题
- 在spring中利用Guava实现本地Cache的具体配置 第一篇<一>
- 深入浅出K-Means算法
- 第一章 多媒体
- 面试题积累篇-简单算法(四)
- boost::asio::io_service::work类
- 欢迎使用CSDN-markdown编辑器
- MySQL高速缓存启动方法及参数详解(query_cache_size)
- 31 原 Mac 安装Elasticsearch 5.0
- ARP的过程
- GitHub开源的MySQL在线更改Schema工具
- [ZOJ2314]/[SGU194] Reactor Cooling 无源汇有上下界网络流
- 图基本算法之图的存储
- mysql游标实现时当内部查询有一次未查询到结果时就自动退出循环解决办法