一、线程池构成:
线程池管理器:初始化和创建线程,启动和停止线程,调配任务;
工作线程:线程池中等待并执行分配的任务
任务接口:添加任务的接口,以提供工作线程调度任务的执行。
任务队列:用于存放没有处理的任务,提供一种缓冲机制,同时具有调度功能,高优先级的任务放在队列前面。
二、线程池代码案例:
2.1、线程池代码:
例1:https://wangpengcheng.github.io/2019/05/17/cplusplus_theadpool/
例2:https://blog.csdn.net/caoshangpa/article/details/80374651
2.2、代码关注点:
任务提交函数:
template<typename F, typename...Args> auto submit(F&& f, Args&&... args) -> std::future<decltype(f(args...))>
线程执行函数:
void ThreadWorker::operator()()
三、总结:
1、线程池中线程创建时不具体指定某个具体任务,而是一个while无限循环函数,该函数不断从队列中取出任务执行。
2、关注2.2两个函数实现
四、参考资料:
线程池代码一: C++线程池
线程池代码二:C++11并发学习之六:线程池的实现