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