C++多线程编程第十三讲--补充知识
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 | //(1)补充一些知识点 //(1.1)虚假唤醒 // wait(), notify_one(), notify_all() 使用非常频繁的接口 // 虚假唤醒是指没有满足条件的时候被唤醒了。 //(1.2)atomic #include<iostream> #include<thread> #include<vector> #include<list> #include<mutex> using namespace std; class A { public : atomic< int > ato; A() { ato = 0; //std::atomic<int> ato2 = ato; //这种赋值操作是不被允许的 //std::atomic<int> ato2(ato.load()); //正确的,需要load函数来辅助 //ato.store(12); // 正确,用来赋值的操作。 } //把收到的消息,入到一个队列中 void inMsgRecvQueue() { int i; for (i = 0; i < 100000; ++i) { ato++; //ato = ato + 1; //不是原子操作 } } //把数据从消息队列中取出 void outMsgRecvQueue() { while ( true ) { // cout << "ato = " << ato << endl; } } private : list< int > msgQueue; mutex my_mutex; //创建一个互斥量 std::condition_variable cond; }; int main() { A myobj; thread myOutMsg(&A::outMsgRecvQueue, std::ref(myobj)); //保证线程中用的同一个对象 thread myInMsg(&A::inMsgRecvQueue, std::ref(myobj)); thread myInMsg2(&A::inMsgRecvQueue, std::ref(myobj)); myOutMsg.join(); myInMsg.join(); myInMsg2.join(); cout << "main thread end..." << endl; return 0; } |
分类:
C++并行编程
posted on 2021-11-03 08:46 xcxfury001 阅读(12) 评论(0) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用