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

C++11并发与多线程笔记(13) 补充知识、线程池浅谈、数量谈、总结

C++11并发与多线程笔记(13) 补充知识、线程池浅谈、数量谈、总结

  • 1、补充一些知识点
    • 1.1 虚假唤醒:
    • 1.2 atomic
  • 2、浅谈线程池:
  • 3、线程创建数量谈:

1、补充一些知识点

1.1 虚假唤醒:

notify_one或者notify_all唤醒wait()后,实际有些线程可能不满足唤醒的条件(例如:多个notify_one语句唤醒,或者多个“out函数“取数据),就会造成虚假唤醒,可以在wait中再次进行判断解决虚假唤醒。
解决:wait中要有第二个参数(lambda),并且这个lambda中要正确判断所处理的公共数据是否存在。

//第8节
my_cond.wait(myUniLock, [=] {if (!test_list.empty())return true;return false;});

1.2 atomic

std::atomic<int> atm = 0;
cout << atm << endl;

这里只有读取atm是原子操作,但是整个这一行代码 cout << atm << endl; 并不是原子操作(中间有多个操作),导致最终显示在屏幕上的值是一个“曾经值”。

std::atomic<int> atm = 0;
auto atm2 = atm; //不可以,//这种定义时初始化操作不允许,显示尝试引用已删除的函数,编译器内部肯定把拷贝构造函数给干掉了
atomic<int> atm3=atm;//不可以

atomic<int> atm2(atm.load());
load():以原子方式atomic对象的值。

atm2.store(12);
store():以原子方式atomic对象的值。
原子操作实质上是:不允许在进行原子对象操作时进行CPU的上下文切换

2、浅谈线程池:

场景设想:服务器程序,每来一个客户端,就创建一个新线程为这个客户提供服务。

问题

  1. 有2万个玩家,不可能给每个玩家创建一个新线程,此程序写法在这种场景下不通。

  2. 程序稳定性问题:编写代码中,“时不时地突然”创建一个线程(来个上下文切换),这种写法,一般情况下不会出错,但是不稳定的

线程池:把一堆线程弄到一起,统一管理。这种统一管理调度,循环利用的方式,就叫做线程池。

实现方式程序启动时,一次性创建好一定数量的线程。这种方式让人更放心,觉得程序代码更稳定。

3、线程创建数量谈:

  1. 线程创建的数量极限的问题
    一般来讲,2000个线程基本就是极限;再创建就会崩溃。

  2. 线程创建数量建议
    a、采用某些技术开发程序提供的建议,遵照建议(创建线程数量=cpu数量)和指示来确保程序高效执行。
    b、创建多线程完成业务;考虑可能被阻塞的线程数量,创建多余最大被阻塞线程数量的线程,如100个线程被阻塞再充值业务,开110个线程就是很合适的
    c、线程创建数量尽量不要超过500个,尽量控制在200个之内;

http://www.lryc.cn/news/131162.html

相关文章:

  • python高级基础
  • 使用线性回归模型优化权重:探索数据拟合的基础
  • 亿级短视频,如何架构?
  • jenkins pipeline方式一键部署github项目
  • Vue 项目搭建
  • 【NetCore】09-中间件
  • 机器学习深度学习——BERT(来自transformer的双向编码器表示)
  • Datawhale Django后端开发入门 Vscode TASK02 Admin管理员、外键的使用
  • 【ES5和ES6】数组遍历的各种方法集合
  • 学科在线教育元宇宙VR虚拟仿真平台落实更高质量的交互学习
  • [python爬虫] 爬取图片无法打开或已损坏的简单探讨
  • vue项目预览pdf功能(解决动态文字无法显示的问题)
  • vue3 样式穿透:deep不生效
  • 云原生反模式
  • 【2023年11月第四版教材】《第5章-信息系统工程(合集篇)》
  • 【qiankun】微前端在项目中的具体使用
  • 云安全与多云环境管理:讨论在云计算和多云环境下如何保护数据、应用程序和基础设施的安全
  • npm install ffi各种失败,换命令npm i ffi-napi成功
  • 0.flink学习资料
  • C语言:字符函数和字符串函数
  • 基于.Net Core开发的医疗信息LIS系统源码
  • 部署工业物联网可以选择哪些通信方案?
  • flutter-移动端适配
  • MySQL 常用函数
  • 动态路由的实现—正则表达式
  • Android实现超出固定行数折叠文字“查看全文“、“收起全文“
  • Python上楼梯问题:递归解法探究(斐波那契变种)(记忆化递归)
  • AI重新定义音视频生产力“新范式”
  • Jmeter生成可视化的HTML测试报告
  • 5G技术与其对智能城市、物联网和虚拟现实领域的影响