互斥器

本文介绍了Windows环境下互斥器的创建、操作及使用方法,并对比了Linux环境下互斥锁的初始化、加锁与解锁过程。文章还强调了互斥器与互斥锁在多线程和多进程间同步资源访问的重要作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用方法: 
1、创建一个互斥器:CreateMutex; 
2、打开一个已经存在的互斥器:OpenMutex; 
3、获得互斥器的拥有权:WaitForSingleObject、WaitForMultipleObjects 等一类等待的函数……(可能造成阻塞); 
4、释放互斥器的拥有权:ReleaseMutex; 
5、关闭互斥器:CloseHandle
HANDLE WINAPI CreateMutex( __in_opt LPSECURITY_ATTRIBUTES lpMutexAttributes, __in BOOL bInitialOwner, __in_opt LPCTSTR lpName );

lpMutexAttributes : 第一个参数表示安全控制,一般直接传入NULL。                                             
bInitialOwner第二个参数用来确定互斥量的初始拥有者
    如果传入TRUE表示互斥量对象内部会记录创建它的线程的线程ID号并将递归计数设置为1,由于该线程ID非零,所以互斥量处于未触发状态,表示互斥量为创建线程拥有。
    如果传入FALSE,那么互斥量对象内部的线程ID号将设置为NULL,递归计数设置为0,这意味互斥量不为任何线程占用,处于触发状态。
lpName第三个参数用来设置互斥量的名称,在多个进程中的线程就是通过名称来确保它们访问的是同一个互斥量。
Linux互斥锁:
初始化一个互斥锁:pthread_mutex_init()函数;
加锁:pthread_mutex_lock()函数或者pthread_mutex_trylock()函数
        使用pthread_mutex_lock()函数进行加锁时,若此时已经被锁,则尝试加锁的线程会被阻塞,直到互斥锁被其他线程释放
当pthread_mutex_lock()函数有返回值时,说明加锁成功
       而使用pthread_mutex_trylock()函数进行加锁时,若此时已经被锁,则返回EBUSY的错误码
解锁(需要满足两个条件):
          解锁前

,互斥锁必须处于锁定状态;
    必须由加锁的线程进行解锁

当互斥锁使用完成后必须进行清除

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值