0

0

c++如何实现一个线程池(thread pool)_c++多线程任务调度与线程池实现方法

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-11-11 22:00:02

|

987人浏览过

|

来源于php中文网

原创

线程池核心是复用线程以减少开销并高效调度任务,C++中通过std::thread、std::queue、互斥锁、条件变量等实现;包含工作线程、任务队列、同步机制与启停控制;任务以std::function包装入队,线程安全取出执行,配合std::future获取结果;析构时停止队列并等待所有线程完成;适用于常规并发场景,高负载下可优化为work-stealing或无锁结构。

c++如何实现一个线程池(thread pool)_c++多线程任务调度与线程池实现方法

实现一个线程池的核心目标是复用线程、减少频繁创建销毁的开销,并高效调度任务。C++ 中可通过 std::threadstd::queuestd::mutexstd::condition_variablestd::function 实现一个轻量级线程池。

线程池的基本结构

一个典型的线程池包含:

  • 一组工作线程(worker threads)
  • 一个任务队列(task queue)存放待执行的任务
  • 互斥锁保护共享数据
  • 条件变量用于线程等待新任务
  • 控制线程池启动和停止的机制

任务提交与执行机制

使用 std::function 包装任意可调用对象(函数、lambda、bind结果等),放入任务队列中。工作线程从队列取出任务并执行。

关键点在于线程安全:任务队列的访问必须加锁,且线程在无任务时应阻塞等待,而不是忙等。

立即学习C++免费学习笔记(深入)”;

示例代码框架:

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

class ThreadPool {
public:
    explicit ThreadPool(size_t numThreads) : stop(false) {
        for (size_t i = 0; i < numThreads; ++i) {
            workers.emplace_back([this] {
                while (true) {
                    std::function task;
                    {
                        std::unique_lock lock(queue_mutex);
                        condition.wait(lock, [this] { return stop || !tasks.empty(); });
                        if (stop && tasks.empty()) return;
                        task = std::move(tasks.front());
                        tasks.pop();
                    }
                    task();
                }
            });
        }
    }

    template
    auto enqueue(F&& f) -> std::future {
        using return_type = decltype(f());
        auto task = std::make_shared>(
            std::forward(f)
        );
        std::future res = task->get_future();
        {
            std::unique_lock lock(queue_mutex);
            if (stop) throw std::runtime_error("enqueue on stopped ThreadPool");
            tasks.emplace([task]() { (*task)(); });
        }
        condition.notify_one();
        return res;
    }

    ~ThreadPool() {
        {
            std::unique_lock lock(queue_mutex);
            stop = true;
        }
        condition.notify_all();
        for (std::thread &worker : workers)
            worker.join();
    }

private:
    std::vector workers;
    std::queue> tasks;

    std::mutex queue_mutex;
    std::condition_variable condition;
    bool stop;
};

使用方式与注意事项

线程池初始化时指定线程数量,通常设为 CPU 核心数(可用 std::thread::hardware_concurrency() 获取)。

雪鸮AI
雪鸮AI

高效便捷的智能绘图辅助工具,一键生成高质量效果图。

下载

通过 enqueue 提交任务,返回 std::future,可用于获取返回值或等待完成。

例如:

ThreadPool pool(4);

auto result1 = pool.enqueue([]() { return 42; });
auto result2 = pool.enqueue([]() { std::this_thread::sleep_for(std::chrono::seconds(1)); return "done"; });

std::cout << result1.get() << std::endl;
std::cout << result2.get() << std::endl;

注意:任务不应抛出未捕获异常,否则会导致线程退出。建议在任务内部做异常处理。

性能与扩展性考虑

该实现适用于大多数场景,但在高并发下可能因锁竞争成为瓶颈。若需更高性能,可考虑:

  • 每个线程拥有本地任务队列,配合全局队列实现 work-stealing
  • 使用无锁队列(lock-free queue)优化任务提交路径
  • 动态调整线程数量(根据负载)

但这些会显著增加复杂度,一般项目中固定大小线程池已足够。

基本上就这些,核心是理解任务调度与线程同步机制。不复杂但容易忽略细节,比如正确唤醒所有线程和防止虚假唤醒。

相关专题

更多
javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

175

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

96

2025.11.27

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

202

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

190

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

41

2026.01.05

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

479

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

143

2025.12.24

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

60

2025.12.01

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

80

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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