通八洲科技

如何用c++实现一个简单的线程池 提高并发任务处理效率【项目实战】

日期:2026-01-02 00:00 / 作者:尼克
线程池核心由任务队列、工作线程组和控制开关构成:使用std::queue+mutex+condition_variable保证线程安全;固定数量后台线程循环取任务并执行;通过atomic_bool m_stop和notify_all实现优雅关闭。

用 C++ 实现一个简单但实用的线程池,核心在于:任务队列 + 线程集合 + 同步机制。不需要依赖第三方库(如 Boost),C++11 及以上标准就足够。

线程池的基本结构设计

一个最小可用的线程池包含三个关键部分:

关键同步逻辑:如何安全取任务

多个线程从队列取任务时,必须防止竞争和虚假唤醒:

提交任务与优雅关闭

对外提供简洁接口,隐藏内部细节:

一个轻量级实现示例(C++11 兼容)

以下代码可直接编译运行,无外部依赖:

定义类 ThreadPool,私有成员包括:std::vector<:thread> m_workersstd::queue<:function>> m_queuestd::mutex m_mutexstd::condition_variable cvstd::atomic_bool m_stop{false}。构造时按指定数量启动线程,每个线程执行如下循环:
→ 加锁 → 等待非空或停止 → 取任务 → 解锁 → 执行任务 → 继续循环。
enqueue() 内部加锁 push,并 notify_one。