一个boost底下的线程池
来源:互联网 发布:数据库5王珊pdf百度云 编辑:程序博客网 时间:2024/04/29 13:11
一个boost底下的线程池
Boost的thread库中目前并没有提供线程池,我在sorceforge上找了一个用boost编写的线程池。该线程池和boost结合的比较好,并且提供了多种任务执行策略,使用也非常简单。
下载地址:
http://threadpool.sourceforge.net/
使用threadpool:
这个线程池不需要编译,只要在项目中包含其头文件就可以了。
一个简单的例子:
#include <iostream>
#include "threadpool.hpp"
using namespace std;
using namespace boost::threadpool;
// Some example tasks
void first_task()
{
cout << "first task is running\n" ;
}
void second_task()
{
cout << "second task is running\n" ;
}
void task_with_parameter(int value)
{
cout << "task_with_parameter(" << value << ")\n";
}
int main(int argc,char *argv[])
{
// Create fifo thread pool container with two threads.
pool tp(2);
// Add some tasks to the pool.
tp.schedule(&first_task);
tp.schedule(&second_task);
tp.schedule(boost::bind(task_with_parameter, 4));
// Wait until all tasks are finished.
tp.wait();
// Now all tasks are finished!
return(0);
}
任务返回值的获取:
一般异步调用中,返回值的获取有同步获取和异步获取两种形式。
同步获取返回值:
int task_int_23()
{
cout<<"task_int_23()\n";
return 23;
}
future<int> res = schedule(tp, &task_int_23);
res.wait();
cout<<"get res value:"<<res.get()<<endl;
异步获取返回值:
不知道是设计者就不打算使用异步回调获取返回值还是我看的不够仔细,异步获取返回值的方式还真没有找着,只好自己简单的写了一个回调的仿函数来实现异步返回值的获取。
//R为任务函数的返回值类型
template<class R>
class callback_task
{
typedef boost::function<void (R)> callback;
typedef boost::function<R ()> function;
private:
callback c_;
function f_;
public:
//F: 任务执行函数 C:结果回调函数
template<class F,class C>
callback_task(F f,C c)
{
f_ = f;
c_ = c;
}
void operator()()
{
c_(f_());
}
};
通过这个对象可以很容易的实现异步结果的回调。
//task_int_23的结果回调函数
void callback(int k)
{
cout<<"get callback value:"<<k<<endl;
}
//通过回调的形式获取任务的返回值
tp.schedule(callback_task<int>(&task_int_23,&callback));
执行效率:
这个线程池的效率还没有怎么测试过,目前还没有应用到对性能要求比较高的地方,有时间测试一下。
http://www.cnblogs.com/TianFang/archive/2007/08/23/867350.html
- 一个boost底下的线程池
- 一个boost底下的线程池
- 用boost实现的一个简易线程池库
- boost 线程池的使用
- linux下boost的一个扩展线程池-threadpool-的学习
- linux下boost的一个扩展线程池-threadpool-的学习
- 使用boost线程的一个简单的例子
- COPY一个目录底下所有文件的函数
- 使用boost线程池很好的例子
- boost asio 实现一个TCP服务端线程池
- boost线程的interruption
- boost 线程池
- boost线程池教程
- boost线程池
- boost io_service 线程池
- 底下菜单栏的实现
- 一个使用boost::thread_specific_ptr线程本地存储的示例,value将不受其它线程影响
- 用boost::thread起一个线程
- Oracle 10g修改密码的方法及机器改变ip或用户名,连不上oracle的问题
- 寻找第K小元素O(N)算法
- 改进的筛选素数法..
- 碰撞检测 小结
- mysql在windows环境下备份和导入数据库——mysqldump工具
- 一个boost底下的线程池
- Android手机中获取手机号码和运营商信息
- [C] C程序100例_005
- 如何编译openssl x64
- android 改变屏幕亮度
- ACE
- T_User表DAL层书写
- Android SDK 实例代码分析---Accelerometer Play(三)
- Android中的多种文件读写操作方法