C++中如何确保多个并发进程正确的访问共享资源

c++
637
2024/4/9 10:15:58
栏目: 编程语言
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

在C++中,可以使用互斥量(mutex)来确保多个并发进程正确地访问共享资源。互斥量是一种同步原语,它可以确保在任意时刻只有一个进程可以访问共享资源。在访问共享资源之前,进程需要先获取互斥量的锁,并在访问完成后释放锁。

以下是一个简单的示例代码,演示了如何使用互斥量来确保多个进程正确地访问共享资源:

#include <iostream>
#include <thread>
#include <mutex>

std::mutex mtx;
int shared_resource = 0;

void increment_shared_resource(int id) {
    mtx.lock();
    std::cout << "Thread " << id << " is incrementing shared resource" << std::endl;
    shared_resource++;
    std::cout << "Shared resource is now: " << shared_resource << std::endl;
    mtx.unlock();
}

int main() {
    std::thread t1(increment_shared_resource, 1);
    std::thread t2(increment_shared_resource, 2);

    t1.join();
    t2.join();

    return 0;
}

在上面的示例代码中,我们首先定义了一个互斥量mtx,然后在increment_shared_resource函数中使用mtx.lock()mtx.unlock()来获取和释放互斥量的锁。这样可以确保在任意时刻只有一个线程可以执行increment_shared_resource函数,从而避免多个线程同时访问shared_resource导致的数据竞争。

需要注意的是,使用互斥量可以确保共享资源的正确访问,但也会降低程序的性能。因此,在设计并发程序时需要权衡性能和正确性。

辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: c++抽象类有哪些作用