在C++中使用Mutex(互斥锁)来实现多线程同步的方法如下:
包含头文件:首先要包含头文件 <mutex>。
创建Mutex对象:使用 std::mutex 类创建一个Mutex对象。
std::mutex mutex;
mutex.lock() 来加锁。mutex.lock();
mutex.unlock() 来解锁。mutex.unlock();
完整示例代码如下:
#include <iostream>
#include <thread>
#include <mutex>
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() 解锁。这样可以确保在任意时刻只有一个线程可以访问共享资源,从而避免竞争条件和数据竞争。