std::lock_guard<std::mutex> lock(_mutex)
时间: 2024-12-24 12:12:47 浏览: 91
`std::lock_guard<std::mutex> lock(_mutex)` 是 C++11 引入的一种用于管理互斥锁(mutex)的机制,它通过RAII(资源获取即初始化)的方式简化了对互斥锁的管理。
以下是对这一语句的解释:
1. **std::lock_guard**: 这是C++标准库中的一个模板类,用于在作用域内自动管理互斥锁。当一个 `std::lock_guard` 对象被创建时,它会尝试获取传入的互斥锁;当该对象被销毁时(例如,离开其作用域),它会自动释放互斥锁。
2. **std::mutex**: 这是C++标准库中用于线程同步的互斥锁类。互斥锁用于保护共享数据,防止多个线程同时访问导致的数据竞争和不一致。
3. **_mutex**: 这是一个 `std::mutex` 类型的变量,表示需要被管理的互斥锁。
4. **lock(_mutex)**: 这里创建了一个 `std::lock_guard<std::mutex>` 对象,并将 `_mutex` 传递给它。这意味着 `_mutex` 被锁定,直到 `lock` 对象超出其作用域并被销毁为止。
使用 `std::lock_guard` 的好处在于,它可以确保即使在异常或提前返回的情况下,互斥锁也能被正确释放,从而避免死锁的发生。
示例代码如下:
```cpp
#include <iostream>
#include <thread>
#include <mutex>
std::mutex _mutex;
void safe_print(const std::string& message) {
// 创建一个 std::lock_guard 对象,自动管理互斥锁
std::lock_guard<std::mutex> lock(_mutex);
// 此时 _mutex 已被锁定
std::cout << message << std::endl;
// 当 lock 对象超出作用域时,_mutex 会被自动解锁
}
int main() {
std::thread t1(safe_print, "Hello from thread 1");
std::thread t2(safe_print, "Hello from thread 2");
t1.join();
t2.join();
return 0;
}
```
在这个例子中,两个线程会安全地打印消息,而不会因为并发访问而导致数据竞争。
阅读全文
相关推荐

















