C++线程池(固定线程数,条件变量通知,future返回)

参考资料:

  • 《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:
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值