通俗易懂理解==C++ 并发编程Mutex

C++ 并发编程(二):Mutex(互斥锁)

多线程共用同一段代码。
没锁的话,我就锁上了这段代码,然后用完,我就解锁,这样别人就可以用这段代码了。

为了保证数据的一致性,mutex一般用于为一段代码加锁,以保证这段代码的原子性(atomic)操作,即:要么不执行这段代码,要么将这段代码全部执行完毕。
有点顺序的意思。

#include 
#include 
#include 
#include 


std::mutex g_mutex;
int g_count = 0;

void Counter() {
    g_mutex.lock();

    int i = ++g_count;
    std::cout << "count: " << i << std::endl;

    // 前面代码如有异常,unlock 就调不到了。
    g_mutex.unlock();
}

int main() {
    const std::size_t SIZE = 4;

    // 创建一组线程。
    std::vector v;
    v.reserve(SIZE);

    for (std::size_t i = 0; i < SIZE; ++i) {
        v.emplace_back(&Counter);
    }

    // 等待所有线程结束。
    for (std::thread& t : v) {
        t.join();
    }
    
    system("pause");
    return 0;
}

你可能感兴趣的:(通俗易懂理解==C++ 并发编程Mutex)