当前位置: 首页 > article >正文

实战C++手写线程池


课程总目录


文章目录

  • 一、项目必备基础概念
    • 1.1 并发和并行
    • 1.2 多线程的优势
    • 1.3 线程的消耗
    • 1.4 线程池的优势
    • 1.5 线程池的两种模式:fixed模式和cached模式
    • 1.6 线程同步之线程互斥
    • 1.7 线程同步之线程通信
      • 1.7.1 条件变量
      • 1.7.2 信号量
    • 1.8 项目设计图浏览
  • 二、线程池代码展示
  • 三、线程池资源回收死锁问题分析
  • 四、线程资源回收策略修改优化
  • 五、Linux平台编译线程池动态库
  • 六、packaged_task和future机制


一、项目必备基础概念

作为五大池(内存池、连接池、线程池、进程池、协程池)之一,线程池的应用非常广泛,不管是客户端程序,还是后台服务程序,都是提高业务处理能力的必备模块。有很多开源的线程池实现,虽然各自接口使用上稍有区别,但是其核心实现原理都是基本相同的。

1.1 并发和并行

  • CPU单核
  • CPU多核、多CPU

并发:单核上,多个线程占用不同的CPU时间片,物理上还是串行执行的,但是由于每个线程占用的CPU时间片非常短(比如10ms),看起来就像是多个线程都在共同执行一样,这样的场景称作并发(concurrent)

并行:在多核上或者多CPU上,多个线程是在真正的同时执行,这样的场景称作并行(parallel)

1.2 多线程的优势

首先我们要认识到一个问题


http://www.kler.cn/a/324101.html

相关文章:

  • Azure pipeline 通过git命令修改文件
  • C/C++静态库引用过程中出现符号未定义的处理方式
  • 企业生产环境-麒麟V10(ARM架构)操作系统部署kafka高可用集群
  • Apache Paimon、Apache Hudi、Apache Iceberg对比分析
  • C++清除所有输出【DEV-C++】所有编辑器通用 | 算法基础NO.1
  • Java垃圾回收算法
  • windows11下vscode配置lua环境
  • 1欧几里得聚类提取
  • WPF入门教学二十二 多线程与异步编程
  • Django——admin创建和使用
  • 【Python游戏开发】扫雷游戏demo
  • Linux云计算 |【第四阶段】RDBMS1-DAY2
  • 使用python获取百度一下,热搜TOP数据详情
  • 什么是聚类?
  • Docker数据卷有哪些常见的驱动类型?
  • K8S真正删除pod
  • SeeClick: Harnessing GUI Grounding for Advanced Visual GUI Agents论文学习
  • socket编程描述tcp的三次握手
  • Postman/Jmeter接口测试
  • MATLAB中的并行计算:提升性能的策略与实践
  • 有关若依菜单管理的改造
  • 动手学深度学习(李沐)PyTorch 第 4 章 多层感知机
  • golang Unicode api接口
  • 【C++】vector 常用成员函数的模拟实现
  • 使用Go语言的互斥锁(Mutex)解决并发问题
  • Goland的使用