在C++中使用Mutex(互斥锁)来实现多线程同步的方法如下:
1. 包含头文件:首先要包含头文件 `
2. 创建Mutex对象:使用 `std::mutex` 类创建一个Mutex对象。
```cpp
std::mutex mutex;
```
3. 加锁:在需要保护共享资源的代码块之前调用 `mutex.lock()` 来加锁。
```cpp
mutex.lock();
```
4. 解锁:在代码块结束之前使用 `mutex.unlock()` 来解锁。
```cpp
mutex.unlock();
```
完整示例代码如下:
```cpp
#include
#include
#include
std::mutex mutex;
void printMessage(int id, const std::string& message) {
mutex.lock();
std::cout << "Thread " << id << ": " << message << std::endl;
mutex.unlock();
}
int main() {
std::thread t1(printMessage, 1, "Hello");
std::thread t2(printMessage, 2, "World");
t1.join();
t2.join();
return 0;
}
```
在上述示例代码中,我们创建了一个Mutex对象 `mutex`,然后在 `printMessage` 函数中使用 `mutex.lock()` 加锁,在代码块结束之前使用 `mutex.unlock()` 解锁。这样可以确保在任意时刻只有一个线程可以访问共享资源,从而避免竞争条件和数据竞争。