首页 > 后端开发 > C++ > 正文

c++如何实现一个线程池_c++高性能线程池设计与实现【源码】

尼克
发布: 2025-12-15 18:09:24
原创
988人浏览过
C++高性能线程池核心是无锁/低争用任务队列、可控线程生命周期、动态伸缩及防虚假唤醒与泄漏;采用std::queue+mutex+condition_variable封装队列,原子标志控制退出,std::packaged_task支持返回值,可选moodycamel无锁队列等优化。

c++如何实现一个线程池_c++高性能线程池设计与实现【源码】

<p>用 C++ 实现一个高性能线程池,核心在于:任务队列无锁化(或低争用)、线程生命周期可控、支持动态伸缩、避免虚假唤醒与资源泄漏。下面是一个轻量但生产可用的实现思路与关键源码片段。</p>

<H3>1. 无锁任务队列(基于 std::queue + std::mutex 小心封装)</H3>
<p>不必强求完全无锁(易出错),用细粒度互斥+条件变量更稳妥。重点是避免在锁内做耗时操作(如函数调用、内存分配)。</p>
<p>建议:</p>
<ul>
  <li>用 <strong>std::queue<std::function<void()>></strong> 存任务,配合 <strong>std::mutex</strong> 和 <strong>std::condition_variable</strong></li>
  <li>入队只 lock + push + notify_one;出队用 unique_lock + wait + pop,不轮询</li>
  <li>加 move 语义:push(std::move(task)),避免拷贝闭包</li>
</ul>

<H3>2. 线程主循环:带退出感知的 wait-loop</H3>
<p>每个工作线程不能死等,需响应“停止”信号。用原子标志 + 条件变量组合控制。</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/6e7abc4abb9f" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">C++免费学习笔记(深入)</a>”;</p>
<p>典型结构:</p>
                    <div class="aritcle_card">
                        <a class="aritcle_card_img" href="/xiazai/code/9008">
                            <img src="https://img.php.cn/upload/webcode/000/000/009/175763880218775.jpg" alt="iWebMall多用户商城系统">
                        </a>
                        <div class="aritcle_card_info">
                            <a href="/xiazai/code/9008">iWebMall多用户商城系统</a>
                            <p>iWebMall 是一款高性能高扩展能力的开源 LAMP 电子商务软件,定位为大中型电子商务平台软件,服务于有建立电子商务需求的商业客户。这些商业客户不必学习任何计算机编程代码知识,只需要使用 iWebMall 软件他们就可以轻松建立一个功能强大的网上商城,实现用户注册、产品展示、在线定购、在线支付等电子商务功能;iWebMall 集成了产品发布与查询、会员注册登录、购物车、在线订单、在线支付、在</p>
                            <div class="">
                                <img src="/static/images/card_xiazai.png" alt="iWebMall多用户商城系统">
                                <span>0</span>
                            </div>
                        </div>
                        <a href="/xiazai/code/9008" class="aritcle_card_btn">
                            <span>查看详情</span>
                            <img src="/static/images/cardxiayige-3.png" alt="iWebMall多用户商城系统">
                        </a>
                    </div>
                
<ul>
  <li><strong>std::atomic<bool> stop_{false};</strong> 全局退出标记</li>
  <li>循环中:cv_.wait(lock, [&]{ return stop_.load() || !tasks_.empty(); });</li>
  <li>退出前 drain 任务队列(可选),再 join 所有线程</li>
</ul>

<H3>3. 任务提交与返回值支持(std::packaged_task)</H3>
<p>用户常需要获取异步结果。用 <strong>std::packaged_task<T()></strong> 包装任务,返回 <strong>std::future<T></strong>。</p>
<p>示例提交接口:</p>
<pre class="brush:php;toolbar:false;"><code>template <class F, class... Args>
auto submit(F&& f, Args&&... args) 
    -> std::future<std::invoke_result_t<F, Args...>> {
    auto task = std::make_shared<std::packaged_task<std::invoke_result_t<F, Args...>()>>(
        [f = std::forward<F>(f), ...args = std::forward<Args>(args)]() mutable {
            return std::invoke(f, std::move(args)...);
        }
    );
    std::future<std::invoke_result_t<F, Args...>> res = task->get_future();
    {
        std::unique_lock<std::mutex> lk(mtx_);
        tasks_.emplace([task]() { (*task)(); });
    }
    cv_.notify_one();
    return res;
}</code>
登录后复制

4. 高性能增强点(可选但推荐)

进一步压测优化方向:

  • 任务队列改用 moodycamel::ConcurrentQueue(生产级无锁队列,头文件即用)
  • 线程局部缓存(thread_local std::queue)+ 偷任务(work-stealing)提升缓存命中
  • 空闲线程超时回收(std::chrono::steady_clock 记录 last_active_)
  • 构造时预启动 N 个线程,避免运行时频繁创建/销毁开销

基本上就这些。完整源码可在 GitHub 搜索 “cpp-threadpool” 找 star 较高的项目(如 progschj/ThreadPool 或 d99kris/ThreadPool),它们已通过多核压力测试。自己实现时,优先保证正确性与 RAII 资源管理,再逐步加性能特性。

以上就是c++++如何实现一个线程池_c++高性能线程池设计与实现【源码】的详细内容,更多请关注php中文网其它相关文章!

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号