代码拉取完成,页面将自动刷新
libstpool是一个开源的轻便的跨平台的动态c/c++线程池,任务池库, 支持Windows, Linux, Unix, ARM, MAC/OSX, NDK,提供丰富的特性支持.
跨平台
(支持)优先级任务
(支持)动态线程池
(支持)任务分组并对组进行隔离控制
(支持)Linux/MAC
windows
ARM (假设交叉编译链为arm-linux-gcc, 库安装目录放到当前目录下的install_dir中)
NDK
安装libstpoolc++ (对libstpool的简单的c++封装)
头文件:
msglog.h (简单的log API头文件)
stpool_caps.h (能力集定义头文件)
stpool.h (基础API头文件)
stpool_group.h (针对任务分组的API头文件)
stpoolc++.h (c++的封装头文件)
库文件:
使用Makefile生成的库 (一般为非windows系统)
libmsglog.a (生成的log静态库)
libmsglog.so (生成的log动态库)
libstpool.a (生成的libstpool静态库)
libstpool.so (生成的libstpool动态库)
libstpoolc++.a (生成的libstpool c++ 静态库)
libstpoolc++.so (生成的libstpool c++ 动态库)
使用VS生成的库 (windows系统)
libmsglog.lib (生成的log静态库)
libstpool.lib (生成的libstpool静态库)
/** 定义期望获得的能力集 */
eCAPs = eCAP_F_DYNAMIC|eCAP_F_ROUTINE|eCAP_F_TASK_WAIT_ALL;
/** 创建线程池 */
pool = stpool_create("mypool", /** 线程池名 */
eCAPs, /** 期望libstpool提供的的功能特性 */
5, /** 线程池中运行的最大线程数目 */
0, /** 预启动提供服务的的线程数目 */
0, /** 保持线程池创建后调度任务状态 */
1 /** 优先级队列数目 */
);
/** 添加10个任务*/
for (i=0; i<10; i++) {
stpool_add_routine(pool, "mytask", task_run, task_err_handler, NULL, NULL);
}
/** 等待所有任务执行完成 */
stpool_wait_all(pool, -1);
/** 打印线程池的运行状态信息 */
puts( stpool_stat_print(pool) );
/** 释放线程池 */
stpool_release(pool);
##.问题反馈
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。