boost之threadpool(提高之线程池).docVIP

  1. 1、本文档共21页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
boost之threadpool(提高之线程池)

boost之threadpool(提高之线程池) 提高之threadpoolboost之线程池 线程池是基于升压库实现的一个线程池子库,但线程池实现起来不是很复杂。我们从线程池中又能学到什么东西呢? 它是基于升压库实现的,如果大家对升压库有兴趣,看看一个简单的实现还是可以学到点东西的。 线程池基本功能 1、任务封装,包括普通任务(task_func)和优先级任务(prio_task_func)。 2、调度策略,包括fifo_scheduler(先进先出)、lifo_scheduler(后进先出)、prio_scheduler(优先级)。 3、结束策略,包括wait_for_all_tasks(全部任务等待)、wait_for_active_tasks(激活任务等待)、立即(立即结束)。 4、动态修改线程池个数功能。 5、基于未来封装的异步返回值获取功能。 在sorceforge上有一个用升压编写的线程池。该线程池和升压结合的比较好,并且提供了多种任务执行策略,使用也非常简单。下载地址:/这个线程池不需要编译,只要在项目中包含其头文件就可以了。一、源代码分析 快速入门分析(/线程池线程池/快速/库/) 这个例子的代码很简单,但已经全部展示了线程池的核心内容,包括建立、调度、同步等操作。 查看plaincopy到clipboardprint? //创建FIFO线程池容器用两个线程。 池TP(2); /向池中添加一些任务。 TP。时间表(amp;first_task); TP。时间表(amp;second_task); /等待所有任务完成。 wait() TP; //创建FIFO线程池容器用两个线程。 池TP(2); /向池中添加一些任务。 TP。时间表(amp;first_task); TP。时间表(amp;second_task); /等待所有任务完成。 wait() TP; 池的定义具体见池。HPP,但使用了pimpl模式,核心代码见pool_core HPP文件。 下面是池的定义 typedef thread_pool lt;task_func,fifo_scheduler,static_size,resize_controller,wait_for_all_tasks gt;fifo_pool; typedef fifo_pool池; 从上面可以知道,池实际就是fifo_pool,从模板参数可以看到,使用了fifo_scheduler和wait_for_all_tasks。 对于线程池有点理解的都知道,一般都是那几样东西,线程的封装,条件变量,队列数据结构。 所以简单的能做的很简单,复杂的的就看你的策略需求了。 对基于升压库的线程池子库来说,上面的三样东西都是现成的,线程封装和条件变量直接使用螺纹子库就行,队列使用STL的标准容器。 task_adaptors.hpp 对线程任务的封装,所谓任务,我们可以理解成需要运行的函数。 线程池最大限度的使用了功能和绑定功能来封装函数,这点和螺纹子库类似。 文件中涉及的内容主要有三个:task_func、prio_task_func和looped_task_func。 对普通任务的封装 typedef void function0 lt;gt;task_func; 如果对绑定和功能熟悉的应该很好理解。 对优先级任务的封装 类prio_task_func 这个类很简单,重载了两个方法, operator()是仿函数的用法, 运算符 lt;是用于优先级比较使用的,用于STL容器的元素比较。 size_policies.hpp 对大小的封装,包括empty_controller、resize_controller和static_size。 shutdown_policies.hpp 对线程池结束的策略封装,包括wait_for_all_tasks、wait_for_active_tasks和立即。 这几个类很简单,具体操作封装在池中。 线程池运行过程中,包括队列中等待的任务,线程正在运行的任务。 所以结束的时候,对这些任务的策略操作是有选择的。 Scheduling_policies.hpp Encapsulation of task scheduling testing, including fifo_scheduler, lifo_scheduler, and prio_scheduler. In fact, the similarity between the three classes is so high that you might prefer to implement them using inheritance and virtual functions. As you

您可能关注的文档

文档评论(0)

jgx3536 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:6111134150000003

1亿VIP精品文档

相关文档