std::get<C++11多线程库>(03): 子线程的完整性
2021/9/25 17:13:38
本文主要是介绍std::get<C++11多线程库>(03): 子线程的完整性,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1 #include <QCoreApplication> 2 #include <iostream> 3 #include <thread> 4 5 /* 6 * 话题:一定要保证新线程结束之前,访问到的数据变量具有有效性。否则会产生未定义的行为和异常。 7 * 单线程代码中,对象销毁之后再去访问,也会产生未定义行为——不过,线程的生命周期增加了这个问题发生的几率。 8 * 9 * 场景1: 线程函数访问的局变量已销毁。 10 * 初始线程的函数已执行完毕,但新线程中使用了 初始函数中局部变量的指针或引用。 这种情况下, 新线程继续访问将导致未定行为。 11 * 12 * 13 * 场景2:新线程使用一个可调用对象作为线程函数,新线程结束前,可调用对象被销毁。 14 * 可调用对象会被复制一份到新线程的内存空间, 如果可调用对象中包含指针或者引用,在原可调用对象被析构后, 15 * 复制到新线程中的副本可调用对象继续使用指针或者引用,将是未定义的。 16 * 17 * 18 * 处理这种情况的常规方法: 19 * 使线程函数的功能齐全,将数据复制到线程中,而非复制到共享数据中。 20 * 如果使用一个可调用的对象作为线程函数,这个对象就会复制到线程中,而后原始对象就会立即销毁。但对于对象中包含的指针和引用还需谨慎。 21 * 使用一个能访问局部变量的函数去创建线程是一个糟糕的主意(除非十分确定线程会在函数完成前结束)。 22 * 23 * 此外,可以通过join()函数来确保线程在函数完成前结束。 24 */ 25 struct Obj{ 26 Obj(int& i):_i(i){} 27 void operator()(){ 28 for (; _i>0; --_i) //潜在访问隐患:悬空引用 29 std::cout<<"i = "<<_i<<std::endl; 30 } 31 32 private: 33 int& _i; 34 }; 35 int main(int argc, char *argv[]) 36 { 37 QCoreApplication a(argc, argv); 38 39 int x = 10000; //局变量 40 Obj obj(x); 41 std::thread t(obj); 42 //t.join(); //加入式。 等待 新线程的结束,访问变量 x 的引用 _i 不会出问题 43 t.detach(); //分离式。 不等待 新线程的结束, 访问变量 x 的引用 _i 可能会出问题 44 45 return a.exec(); 46 }
这篇关于std::get<C++11多线程库>(03): 子线程的完整性的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-12深入理解 ECMAScript 2024 新特性:Map.groupBy() 分组操作
- 2025-01-11国产医疗级心电ECG采集处理模块
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势