unique_lock()使用

本文介绍了C++中的unique_lock,它比lock_guard更灵活但效率较低。unique_lock的第二个参数可以设置不同的行为,如尝试加锁或不加锁。文章详细讲解了unique_lock的成员函数,如lock()、unlock()、try_lock()和release(),并讨论了锁的粒度对程序效率的影响。此外,还提到了所有权的传递以及在所有权转移过程中可能出现的问题。

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

一、unique_lock()
是一个类模板,可以取代lock_guard(),相比起来前者更灵活,但效率较差,内存占用较多 ,一般工作中推荐使用lock_guard()

二、unique_lock()的第二个参数:
2.1 std::adopt_lock:表示互斥量已经被lock,则在第二个参数添加此标志。(使用此参数则当前线程之前未使用lock())。

	my_mutex1.lock();
	std::lock_guard<std::mutex>myLockGuard(my_mutex1,std::adopt_lock);

2.2 std::try_to_lock():尝试给mute上lock(),如果没有锁定成功会立即返回,并不会产生阻塞。

 	//线程1:
 	std::unique_lock<std::mutex>myLockGuard(my_mutex1,std::try_to_lock);
	if (myLockGuard.owns_lock())
		{
   
			//拿到锁
			msgRecvQueue.push_back(i);
		}
		else
		{
   
			//未拿到锁
			cout << "程序执行,未拿到锁..." << i <<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值