曾格的github

十三、线程池

虚假唤醒:

当 wait() 不带有第二个判断条件参数时会发生虚假唤醒的情况,所以wait()中尽量要带有第二个参数,并且这个lambda表达式要正确判断处理的公共数据是否存在。条件变量很重要,以后会经常用到。

atomic:

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

这里只有读取atm是原子操作,但是整个 cout << atm << endl; 并不是原子操作。

  比如说,atm是2000了,但是输出的还atm=1902的值。

std::atomic<int> atm = 0;
 
auto atm2 = atm; //不是原子操作

 原子变量的赋值:禁用了拷贝构造函数,

load():以原子方式读atomic对象的值,以store方式写入atomic

atomic<int> atm2(atm.load());

原子操作实质上是:不允许CPU在进行原子对象操作时进行上下文切换。

浅谈线程池:

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

问题:

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

2、程序稳定性问题:编写代码中,偶尔创建一个线程,这种写法,让人感到不安,有时候资源紧张会创建失败;

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

实现方式:程序启动时,一次性创建好一定数量的线程。10(第十一个来了就先等待),8,100-200。这种方式让人更放心,觉得程序代码更稳定。

线程创建数量谈:

1、线程创建的数量极限的问题

一般来讲,2000个线程基本就是极限;在创建就会崩溃。

2、线程创建数量建议

a、采用某些计数开发程序:采用api接口商提供建议,遵照建议和指示来确保程序高效执行。

b、创建多线程完成业务;一个线程等于一条执行通路;

c、线程创建数量尽量不要超过500个,尽量控制在200个之内;

posted @ 2021-09-17 21:27  曾格  阅读(41)  评论(0编辑  收藏  举报
Live2D