多线程之互斥量mutex

本文介绍了在C++中如何使用互斥量(mutex)来实现多线程间的同步,防止并发访问同一资源导致的问题。通过定义、创建、等待、释放和关闭互斥量的步骤详细阐述了其工作原理,并提供了示例代码。
摘要由CSDN通过智能技术生成

我们经常会遇到同一个进程中的不同线程(或者不同进程的不同线程)需要访问同一块内存块(例如同一个指针、共享内存),为了避免同时访问,可以使用互斥量(MUTEX)。

互斥量使用步骤如下:

1、  定义一个操作句柄:HANDLE m_hMutex;

2、  创建或者打开互斥量:hMutex =CreateMutex(NULL,FALSE,”TEST_MUTEX”);

可以创建有名字的互斥量,当不同进程中的线程需要访问统一内存块时,就非常有用。一个进程创建,另一个进程只要调用

hMutex =OpenMutex(MUTEX_ALL_ACCESS,FALSE, ”TEST_MUTEX”);打开即可使用同一个互斥量进行控制。

3、  等待互斥量空闲:WaitForSingleObject(m_hMutex,INFINITE);

4、  释放互斥量,让它处于空闲状态:ReleaseMutex(m_hMutex);

5、  关闭互斥量: CloseHandle(m_hMutex);

进程中止前,一定要释放互斥体,如不慎未采取这个措施,就会将这个互斥体标记为废弃,并自动释放所有权。共享这个互斥体的其他

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值