qthread run结束了算销毁吗_C++核心准则CP.41:尽量回避线程的生成和销毁处理

a3fad53a449dcbefa7d0b4a60c56486b.png

CP.41: Minimize thread creation and destruction

CP.41:尽量回避线程的生成和销毁处理

Reason(原因)

Thread creation is expensive.

创建线程代价高昂。

Example(示例)

void worker(Message m){    // process}void dispatcher(istream& is){    for (Message m; is >> m; )        run_list.push_back(new thread(worker, m));}

This spawns a thread per message, and the run_list is presumably managed to destroy those tasks once they are finished.

Instead, we could have a set of pre-created worker threads processing the messages

代码中为每个消息生成一个线程,而且run_list很可能准备在任务结束时销毁它们。

作为改善,我们可以准备一组事先生成的工作线程来处理这些消息。​

Sync_queue work;void dispatcher(istream& is){    for (Message m; is >> m; )        work.put(m);}void worker(){    for (Message m; m = work.get(); ) {        // process    }}void workers()  // set up worker threads (specifically 4 worker threads){    joining_thread w1 {worker};    joining_thread w2 {worker};    joining_thread w3 {worker};    joining_thread w4 {worker};}

Note(注意)

If your system has a good thread pool, use it. If your system has a good message queue, use it.

如果你的系统包含一个优秀的线程池,使用它。如果你的系统包含一个优秀的消息队列,使用它。

Enforcement(实施建议)

???

原文链接

https://github.com/isocpp/CppCoreGuidelines/blob/master/CppCoreGuidelines.md#cp41-minimize-thread-creation-and-destruction

新书介绍

以下是本人3月份出版的新书,拜托多多关注!

866aa213b6cfa6f3d55a343cd9d206b3.png

本书利用Python 的标准GUI 工具包tkinter,通过可执行的示例对23 个设计模式逐个进行说明。这样一方面可以使读者了解真实的软件开发工作中每个设计模式的运用场景和想要解决的问题;另一方面通过对这些问题的解决过程进行说明,让读者明白在编写代码时如何判断使用设计模式的利弊,并合理运用设计模式。

对设计模式感兴趣而且希望随学随用的读者通过本书可以快速跨越从理解到运用的门槛;希望学习Python GUI 编程的读者可以将本书中的示例作为设计和开发的参考;使用Python 语言进行图像分析、数据处理工作的读者可以直接以本书中的示例为基础,迅速构建自己的系统架构。


觉得本文有帮助?请分享给更多人。

关注微信公众号【面向对象思考】轻松学习每一天!

面向对象开发,面向对象思考!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值