【c++】线程同步改错题 (互斥体)
2022/8/29 14:22:50
本文主要是介绍【c++】线程同步改错题 (互斥体),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
题目:
#include <iostream> #include <windows.h> #include <tchar.h> // 我想使用线程,让线程按我制定?的方案执行,但是总失败 // 起床-》吃饭-》工作 -》回家 -》起床 HANDLE mutext1; HANDLE mutext2; HANDLE mutext3; HANDLE mutext4; DWORD CALLBACK Step1(void* param) { while (1) { WaitForSingleObject(mutext1, -1); printf("起床\n"); ReleaseMutex(mutext2); } return 0; } DWORD CALLBACK Step2(void* param) { while (1) { WaitForSingleObject(mutext2, -1); printf("吃饭\n"); ReleaseMutex(mutext3); } return 0; } DWORD CALLBACK Step3(void* param) { while (1) { WaitForSingleObject(mutext3, -1); printf("工作\n"); ReleaseMutex(mutext3); } return 0; } DWORD CALLBACK Step4(void* param) { while (1) { WaitForSingleObject(mutext4, -1); printf("回家\n"); ReleaseMutex(mutext1); } return 0; } int main() { mutext1 = CreateMutexW(NULL, FALSE, NULL); mutext2 = CreateMutexW(NULL, FALSE, NULL); mutext3 = CreateMutexW(NULL, FALSE, NULL); mutext4 = CreateMutexW(NULL, FALSE, NULL); CreateThread(NULL, NULL, Step1, NULL, NULL, NULL); CreateThread(NULL, NULL, Step2, NULL, NULL, NULL); CreateThread(NULL, NULL, Step3, NULL, NULL, NULL); CreateThread(NULL, NULL, Step4, NULL, NULL, NULL); Sleep(50000); return 0; }
错误原因:互斥体只能在自己线程解锁。
解决方案不唯一,用事件也可以实现。
这里还是改互斥体的错误。
#include <iostream> #include <windows.h> #include <tchar.h> // 我想使用线程,让线程按我制定?的方案执行,但是总失败 // 起床-》吃饭-》工作 -》回家 -》起床 HANDLE mutext1; int step = 0; // 错误原因:互斥体只能在自己线程中解锁,其他线程解锁无效 DWORD CALLBACK Step1(void* param) { while (1) { WaitForSingleObject(mutext1, -1); // 等待激发态,并设置为非激发态 if (step % 4 == 0) { step++; printf("起床\n"); Sleep(500); } ReleaseMutex(mutext1); } return 0; } DWORD CALLBACK Step2(void* param) { while (1) { WaitForSingleObject(mutext1, -1); if (step % 4 == 1) { step++; printf("吃饭\n"); Sleep(500); } ReleaseMutex(mutext1); } return 0; } DWORD CALLBACK Step3(void* param) { while (1) { WaitForSingleObject(mutext1, -1); if (step % 4 == 2) { step++; printf("工作\n"); Sleep(500); } ReleaseMutex(mutext1); } return 0; } DWORD CALLBACK Step4(void* param) { while (1) { WaitForSingleObject(mutext1, -1); if (step % 4 == 3) { step++; printf("回家\n\n"); Sleep(500); } ReleaseMutex(mutext1); } return 0; } int main() { mutext1 = CreateMutexW(NULL, FALSE, NULL); //mutext2 = CreateMutexW(NULL, FALSE, NULL); //mutext3 = CreateMutexW(NULL, FALSE, NULL); //mutext4 = CreateMutexW(NULL, FALSE, NULL); CreateThread(NULL, NULL, Step1, NULL, NULL, NULL); CreateThread(NULL, NULL, Step2, NULL, NULL, NULL); CreateThread(NULL, NULL, Step3, NULL, NULL, NULL); CreateThread(NULL, NULL, Step4, NULL, NULL, NULL); Sleep(50000); return 0; }
当然要注意的地方,step++ 还没做完,线程立即崩溃,一样还是会有死锁问题,不过不属于题目了。
这篇关于【c++】线程同步改错题 (互斥体)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-13PingCAP 戴涛:构建面向未来的金融核心系统
- 2024-05-09flutter3.x_macos桌面os实战
- 2024-05-09Rust中的并发性:Sync 和 Send Traits
- 2024-05-08使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B
- 2024-05-08完工标准(DoD)与验收条件(AC)究竟有什么不同?
- 2024-05-084万 star 的 NocoDB 在 sealos 上一键起,轻松把数据库编程智能表格
- 2024-05-08Mac 版Stable Diffusion WebUI的安装
- 2024-05-08解锁CodeGeeX智能问答中3项独有的隐藏技能
- 2024-05-08RAG算法优化+新增代码仓库支持,CodeGeeX的@repo功能效果提升
- 2024-05-08代码报错不用愁,CodeGeeX一键完成代码修复、错误解释的功能上线了!