第六节 unique_lock(类模板)详解
1.unique_lock取代lock_guard
unique_lock比lock_guard灵活很多(多出来很多用法),效率差一点。
unique_lock<mutex> myUniLock(myMutex);
2.unique_lock的第二个参数
2.1 std::adopt_lock:
表示这个互斥量已经被lock(),即不需要在构造函数中lock这个互斥量了。
前提:必须提前lock
lock_guard中也可以用这个参数,可以省去unlock。
2.2 std::try_to_lock:
尝试用mutex的lock()去锁定这个mutex,但如果没有锁定成功,会立即返回,不会阻塞在那里;
使用try_to_lock的原因是防止其他的线程锁定mutex太长时间,导致本线程一直阻塞在lock这个地方
前提:不能提前lock();
owns_lock()方法判断是否拿到锁,如拿到返回true
没拿到锁可以做其他的事情。
2.3 std::defer_lock:
如果没有第二个参数就对mutex进行加锁,加上defer_lock是始化了一个没有加锁的mutex
不给它加锁的目的是以后可以调用unique_lock的一些方法
前提:不能提前lock
3.unique_lock的成员函数(前三个与std::defer_lock联合使用)
3.1 lock():加锁
unique_lock<mutex> myUniLock(myMutex, defer_lock); myUniLock.lock();
3.2unlock():解锁。
unique_lock<mutex> myUniLock(myMutex, defer_lock); myUniLock.lock(); //处理一些共享代码 myUniLock.unlock(); //处理一些非共享代码 myUniLock.lock(); //处理一些共享代码
原文链接:https://blog.csdn.net/qq_38231713/article/details/106092134