std::mutex

本文通过一个简单的C++示例展示了如何利用std::mutex确保多线程环境下全局变量的安全修改。示例中创建了10个线程同时递增一个全局整型变量counter,并使用mutex来避免竞态条件。介绍了mutex的基本用法,包括lock和unlock方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mutex代码示例

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

using namespace std;
volatile int counter(0);
std::mutex mu;

void count()
{
    for(int i = 0;i < 10000;++i)
    {
        if(mu.try_lock())
        {
            counter++;
            mu.unlock();
        }
    }
}

int main(int argc, char *argv[])
{
    cout << "Hello World!" << endl;

    std::thread myThreads[10];

    for(int i = 0;i < 10; ++i)
        myThreads[i] = std::thread(count);

    for(auto& mythread : myThreads)
    {
        mythread.join();
    }

    std::cout << "counter = " << counter;;
    return 0;
}
  1. std::mutex不允许拷贝构造,也不允许 move 拷贝,最初产生的 mutex 对象是处于 unlocked 状态的。
  2. lock(),调用线程将锁住该互斥量。线程调用该函数会发生下面 3 种情况:(1). 如果该互斥量当前没有被锁住,则调用线程将该互斥量锁住,直到调用 unlock之前,该线程一直拥有该锁。(2). 如果当前互斥量被其他线程锁住,则当前的调用线程被阻塞住。(3). 如果当前互斥量被当前调用线程锁住,则会产生死锁(deadlock)。
  3. unlock(), 解锁,释放对互斥量的所有权。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值