C++那些事之helgrind并发编程检测

C++那些事之helgrind并发编程检测

大纲

  • 死锁

  • 数据竞争

  • 提问

通常我们在写多线程程序的时候很容易遇到两个问题:

  • 死锁了,不知道什么原因导致

  • 数据不一致,多个线程没保护数据

那么有没有工具来检测这两种场景呢

答案是有的,我们可以使用valgrind的helgrind工具检测这两个问题,为了使本文讲解的更加丝滑,引出了几个例子。

注:完整示例及修复示例已更新至星球。

死锁

假设有两个线程互相持有对方的锁,此时我们可以模拟出死锁,例如:

void thread_func1() {
    std::lock_guard<std::mutex> lock1(mutex1);
    std::this_thread::sleep_for(std::chrono::milliseconds(100));
    std::lock_guard<std::mutex> lock2(mutex2);
}

void thread_func2() {
    std::lock_guard<std::mutex> lock2(mutex2);
    std::this_thread::sleep_for(std::chrono::milliseconds(100));
    std::lock_guard<std::mutex> lock1(mutex1);
}

helgrind使用的方法如下:

valgrind --tool=helgrind ./a.out

此时我们可以看到死锁的位置,例如这个示例中指出了两个线程在对应位置发生了死锁

thread_func2() (deadlock.cc:18)
thread_func1() (deadlock.cc:12)

ee99a6a0eb3a197a84536fb94eb42261.jpeg

数据竞争

假设有一个共享变量,我们在多线程对它增加10w次,这个结果是多少呢?

很明显这里产生了多线程竞争全局变量的问题,最终的结果不一致,使用helgrind检测方法同上。

int shared_var = 0; 

void increment() {
    for (int i = 0; i < 100000; ++i) {
        ++shared_var; 
    }
}

此时,我们可以看到data race的行数是哪一行,然后去解决问题。

a5cd6d58d86e328871f2bcae340a4ebe.jpeg

最后,留几个问题吧:

1.上面这两个有问题的代码,如何修复?

2.除了上面工具,还有其他办法?

本节完

揭秘答案,戳下方呀~

ef603d2f1e31f75d86664abd68f7373c.jpeg

往期推荐:

向量数据库milvus源码剖析之开篇

热度更新,手把手实现工业级线程池

玩转cpp小项目星球3周年了!

91ce6c096dda55baf5e384df65e9a1ad.jpeg

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值