C++如何实现一个简单的线程池?(代码示例)

发布时间 - 2025-12-29 00:00:00    点击率:
该线程池实现基于任务队列、工作线程组与互斥锁+条件变量同步机制,支持C++11以上标准,具备RAII资源管理、移动语义和lambda任务提交功能。

用 C++ 实现一个简单但可用的线程池,核心是:一个任务队列 + 一组工作线程 + 同步机制(互斥锁 + 条件变量)。下面是一个轻量、无依赖(仅标准库)、可直接编译运行的版本。

基本结构与关键组件

线程池包含三部分:
– 任务队列(std::queue<:function>>
– 线程集合(std::vector<:thread>
– 控制同步的 std::mutexstd::condition_variable
所有线程在空闲时等待新任务;提交任务后通知至少一个线程唤醒执行。

线程池类定义(含注释)

以下代码使用 C++11 及以上标准,支持 lambda、移动语义和 RAII 管理:

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 

class ThreadPool {
private:
    std::vector workers;
    std::queue> tasks;
    std::mutex mtx;
    std::condition_variable cv;
    std::atomic stop{false};

public:
    explicit ThreadPool(size_t n) {
        for (size_t i = 0; i < n; ++i) {
            workers.emplace_back([this] {
                while (true) {
                    std::function task;
                    {
                        std::unique_lock lock(mtx);
                        cv.wait(lock, [this] { return stop.load() || !tasks.empty(); });
                        if (stop.load() && tasks.empty()) return;
                        task = std::move(tasks.front());
                        tasks.pop();
                    }
                    task(); // 执行任务
                }
            });
        }
    }

    ~ThreadPool() {
        {
            std::unique_lock lock(mtx);
            stop = true;
        }
        cv.notify_all();
        for (auto& t : workers) {
            if (t.joinable()) t.join();
        }
    }

    template
    void enqueue(F&& f, Args&&... args) {
        auto task = std::make_shared>(
            std::bind(std::forward(f), std::forward(args)...)
        );
        {
            std::unique_lock lock(mtx);
            tasks.emplace([task]() { (*task)(); });
        }
        cv.notify_one();
    }
};

如何使用(完整可运行示例)

下面是一个 main 函数,提交 10 个带编号的打印任务,观察并发执行效果:

#include 
#include 
#include 

int main() {
    ThreadPool pool(3); // 创建含 3 个工作线程的池

    for (int i = 0; i < 10; ++i) {
        pool.enqueue([i] {
            std::this_thread::sleep_for(std::chrono::milliseconds(100));
            std::cout << "Task " << i << " executed by thread "
                      << std::this_thread::get_id() << '\n';
        });
    }

    // 主线程不立即退出,确保所有任务完成(实际项目中可加 wait 机制)
    std::this_thread::sleep_for(std::chrono::seconds(2));
    return 0;
}

注意事项与改进点

这个实现适合学习和轻量场景,真实项目中可考虑:

  • 添加任务等待机制(如 wait_all() 或返回 std::future
  • 限制队列长度防止内存暴涨(加 size 检查 + 阻塞或丢弃策略)
  • 支持优先级任务队列(用 std::priority_queue
  • 动态调整线程数(需更复杂的生命周期管理)
  • 异常安全:worker 中捕获并传播异常(当前会终止线程)

基本上就这些。它不复杂但容易忽略 stop 标志和 notify 的时机 —— 错了就会死锁或漏任务。


# ai  # c++  # ios  # stream  # 同步机制  # 标准库  # red  # void  # Lambda  # 线程  # Thread  # 并发  # function  # 是一个  # 死锁  # 就会  # 互斥  # 闲时  # 错了  # 可直接  # 它不  # 如何使用  # 资源管理 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何在七牛云存储上搭建网站并设置自定义域名?  非常酷的网站设计制作软件,酷培ai教育官方网站?  无锡营销型网站制作公司,无锡网选车牌流程?  如何在Windows 2008云服务器安全搭建网站?  网站制作报价单模板图片,小松挖机官方网站报价?  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  如何快速搭建高效简练网站?  Laravel如何创建自定义中间件?(Middleware代码示例)  详解vue.js组件化开发实践  实例解析angularjs的filter过滤器  JS弹性运动实现方法分析  三星网站视频制作教程下载,三星w23网页如何全屏?  Laravel如何处理CORS跨域请求?(配置示例)  如何在腾讯云免费申请建站?  Swift中switch语句区间和元组模式匹配  油猴 教程,油猴搜脚本为什么会网页无法显示?  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  大同网页,大同瑞慈医院官网?  魔方云NAT建站如何实现端口转发?  Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  LinuxShell函数封装方法_脚本复用设计思路【教程】  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  Swift中循环语句中的转移语句 break 和 continue  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  详解阿里云nginx服务器多站点的配置  如何用西部建站助手快速创建专业网站?  如何在腾讯云服务器上快速搭建个人网站?  如何快速登录WAP自助建站平台?  Bootstrap整体框架之CSS12栅格系统  Laravel如何创建自定义Artisan命令?(代码示例)  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】  焦点电影公司作品,电影焦点结局是什么?  如何用已有域名快速搭建网站?  如何在腾讯云服务器快速搭建个人网站?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  如何登录建站主机?访问步骤全解析  Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  网站建设保证美观性,需要考虑的几点问题!  如何快速搭建高效可靠的建站解决方案?  Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布  如何在Ubuntu系统下快速搭建WordPress个人网站?