线程池设计与实现

线程池分析

我们知道线程并非越多越好。创建和销毁线程开销大,线程栈占用内存,频繁上下文切换消耗 CPU,大量线程同时唤醒还可能引发系统负载尖峰甚至宕机。

线程池的优势在于:在服务启动时预先创建一定数量的线程,任务到来时直接复用空闲线程执行,任务完成后线程归还而非销毁,从而避免频繁创建/销毁线程的性能损耗,提升系统吞吐与响应能力。因此设计时,采用以下两种模式相结合的方法增加项目可用性。

  • Fixed 模式:线程数固定,通常设为 CPU 核心数,适用于负载稳定、任务量可预测的场景。
  • Cached 模式:线程数动态伸缩,按需创建但不超过上限;空闲线程超时(如 60 秒)后自动回收,适合突发性、短时任务。

线程池设计


线程池执行流程与核心原理

线程池执行流程:主线程初始化线程池并设置工作模式后,通过submitTask提交任务到共享任务队列;工作线程在ThreadFunc中通过双条件变量机制notEmpty_等待任务、notFull_控制队列容量)协调任务消费;任务执行结果通过Result对象的信号量同步机制wait/post)返回给调用方;析构时触发停机协议 ,通过exitCnd_条件变量确保所有线程安全退出。核心知识点包括:RAII锁管理类型擦除Any类存储任意返回类型)、原子操作 以及动态线程伸缩,一起共同构成了一个高性能且线程安全的并发基础设施,解决了多线程编程中的资源竞争、死锁风险和优雅停机等关键挑战。


项目反思

  1. 析构死锁问题:线程池在析构时等待工作线程退出,因同步逻辑不当导致主线程与工作线程相互等待,进程无法退出。
  2. 跨平台差异:Windows 下正常运行的代码在 Linux 下出现死锁,源于线程调度和条件变量行为的平台差异。

分析定位问题方法: 主要通过gdb attach到正在运行的进程,通过info threads,thread tid,bt等命令查看各个线程的调用 堆栈信息,结合项目代码,定位到发生死锁的代码片段,分析死锁问题发生的原因,xxxx,以及最终的 解决方案。


项目gitte地址

相关推荐
王老师青少年编程4 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮5 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
样例过了就是过了6 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
谭欣辰6 小时前
C++ 排列组合完整指南
开发语言·c++·算法
橙子也要努力变强7 小时前
信号捕捉底层机制-机理篇2
linux·服务器·c++
盐焗鹌鹑蛋7 小时前
【C++】stack和queue类
c++
郝学胜-神的一滴8 小时前
罗德里格斯旋转公式(Rodrigues‘ Rotation Formula)完整推导
c++·unity·godot·图形渲染·three.js·unreal
lzh200409198 小时前
深入理解进程:从PCB内核结构到写时拷贝的底层实战
linux·c++
aseity9 小时前
跨平台项目中QString 与 非Qt 跨平台动态库在字符集上的一个实用的互操作约定.
c++·经验分享
CN-Dust9 小时前
【C++】while语句例题专题
数据结构·c++·算法