在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()
解锁。这样可以确保在任意时刻只有一个线程可以访问共享资源,从而避免竞争条件和数据竞争。