std::unique_lock 怎么用
时间: 2023-12-08 14:58:31 浏览: 29
std::unique_lock 是一个 C++11 中用于管理互斥量的 RAII 类,用法如下:
```
#include <mutex>
std::mutex mtx; // 互斥量
std::unique_lock<std::mutex> lck(mtx); // 用unique_lock管理互斥量
// 临界区
```
通过这种方式,std::unique_lock 类会在创建时锁定互斥量,析构时自动释放锁。也可以通过调用 unlock() 方法手动释放锁。
注意,std::unique_lock 不仅可以用于 std::mutex,也可以用于其他一些符合特定接口的同步对象,比如 std::shared_mutex 等。
相关问题
std::unique_lock使用案例
std::unique_lock是C++11中提供的一种锁的封装类,它提供了比std::lock_guard更加灵活的锁定机制。下面是std::unique_lock的一个使用案例:
在一个类A中,我们增加了一个成员函数rtn_unique_lock(),它返回一个局部的std::unique_lock对象。在inMsgRecvQueue()函数中,我们使用for循环向msgRecvQueue中添加元素。在每次循环中,我们都会调用rtn_unique_lock()函数返回一个std::unique_lock对象,然后使用该对象锁定互斥量,向msgRecvQueue中添加元素,最后该对象会在循环结束时被销毁,从而释放互斥量。这个案例展示了std::unique_lock的灵活性和方便性,可以更加方便地控制锁的生命周期。
std::unique_lock使用代码案例
std::unique_lock是C++11中提供的一种锁的封装类,它提供了比std::lock_guard更加灵活的锁管理方式。下面是一个使用std::unique_lock的代码案例:
std::mutex my_mutex;
std::vector<int> msgRecvQueue;
void inMsgRecvQueue() {
for (int i = 0; i < 100000; ++i) {
std::unique_lock<std::mutex> sbguard1(my_mutex);
msgRecvQueue.push_back(i);
}
}
在这个例子中,我们定义了一个互斥量my_mutex和一个存储int类型数据的vector容器msgRecvQueue。在函数inMsgRecvQueue中,我们使用std::unique_lock对my_mutex进行了加锁,并向msgRecvQueue中添加了100000个元素。由于std::unique_lock的灵活性,我们可以在需要的时候手动释放锁,而不是像std::lock_guard那样在作用域结束时自动释放锁。