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

