前文:如何避免死锁:方法一_御坂美琴1的博客-CSDN博客
unique_lock<mutex> 大部分情况下可以和lock_guard<mutex>替换。但是前者更灵活,同时也占用了更多的内存资源。
unique_lock也是一个模板类。
unique_lock<mutex> guard(mt,defer_lock);
//第二个参数表示在构造的时候不用上锁,后面在上锁。
/*
do_something()
*/
guard.lock();//做完一些事情后,手动进行加锁
//注意不是mt.lock而是guard,lock()
/*
do_something()
*/
//加完锁之后再做些事情
guard.unlock();//手动的进行解锁
示例代码如下:
#include<iostream>
#include<thread>
#include<mutex>
#include<Windows.h>
using namespace std;
mutex mt;
void thread1(int id, const string& str);
int main(void)
{
thread t1(thread1, 1, "Hello world");
t1.join();
return 0;
}
//void thread1(int id, const string& str)
//{
// lock_guard<mutex> guard(mt);
// cout << "Thread" << id << " : " << str << endl;
//}
void thread1(int id, const string& str)
{
unique_lock<mutex> guard(mt,defer_lock);
/*
* do_something();
*/
guard.lock();
cout << "Thread" << id << " : " << str << endl;
guard.unlock();
int sum = 0;
for (int i = 1; i <= 100; i++)
sum += i;
guard.lock();//后面不需要手动解锁也可以
cout << "Thread " << id << ": " << str;
}
用unique_lock避免死锁,如下,就不需要自己解锁了: