参考资料:
- 《C++并发编程实战》
- https://en.cppreference.com
代码下载
https://github.com/541380000/csdn_share/tree/main/threadpool_cpp
实现(见注释)
#pragma once
#include <vector>
#include <queue>
#include <thread>
#include <atomic>
#include <condition_variable>
#include <future>
#include <functional>
#include <stdexcept>
using std::thread;
using std::max;
using std::min;
class ThreadPool
{
using Task = std::function<void()>;
// 执行任务的线程
std::vector<std::thread> pool;
// 任务队列
std::queue<Task> tasks;
// 保护任务队列的锁
std::mutex taskQueueLock;
// 条件变量,所有线程在该变量上等待。有任务加入任务队列时,唤醒该条件变量
std::condition_variable cvTask;
// 是否已经关闭,关闭后,无法再提交任务
std::atomic<bool> isStopped;
// 空闲线程个数
std::atomic<uint32_t> idleThreadNumber;
public: