当前位置: 首页 > 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

相关文章:

  • 线段树(Segment Tree)和树状数组
  • 【汽车电子架构】AutoSAR从放弃到入门专栏导读
  • 「AI学习笔记」深度学习的起源与发展:从神经网络到大数据(二)
  • 蓝桥备赛指南(5)
  • 留学生scratch计算机haskell函数ocaml编程ruby语言prolog作业VB
  • Excel 技巧21 - Excel中整理美化数据实例,Ctrl+T 超级表格(★★★)
  • 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的使用