目录
1.unique_lock取代lock_guard
2. unique_lock的第二个参数
2.1 std::adopt_lock
2.2 std::try_to_lock
2.3 std::defer_lock
3. unique_lock的成员函数
3.1 lock(),加锁
3.2 unlock(),解锁
3.3 try_lock()
3.4 release()
4. unique_lock所有权的传递
1.unique_lock取代lock_guardunique_lock是个类模板,工作中,一般lock_guard(推荐使用);lock_guard取代了mutex的lock()和unlock();
unique_lock比lock_guard灵活很多,效率上差一点,内存占用多一点。
2. unique_lock的第二个参数lock_guard可以带第二个参数:
std::lock_guard sbguard1(my_mutex1, std::adopt_lock);// std::adopt_lock标记作用;
2.1 std::adopt_lock
表示这个互斥量已经被lock了(你必须要把互斥量提前lock了 ,否者会报异常);
std::adopt_lock标记的效果就是假设调用一方已经拥有了互斥量的所有权(已经lock成功了);通知lock_guard不需要再构造函数中lock这个互斥量了。
unique_lock也可以带std::adopt_lock标记,含义相同,就是不希望再unique_lock()的构造函数中lock这个mutex。
用std::adopt_lock的前提是,自己需要先把mutex lock上;用法与lock_guard相同。
2.2 std::try_to_lock我们会尝试用mutex的lock()去锁定这个mutex,但如果没有锁定成功,我也会立即返回,并不会阻塞在那里;
用这个try_to_lock的前提是你自己不能先lock。实例代码如下:
#include
#include
#include
#include
#include
#include
using namespace std;
class A
{
public:
void inMsgRecvQueue()
{
for (int i = 0; i < 10000; i++)
{
cout
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?