c – 与线程相关的问题并对其进行调试

前端之家收集整理的这篇文章主要介绍了c – 与线程相关的问题并对其进行调试前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
这是我关于内存管理问题的上一篇文章的后续内容.以下是我所知道的问题.

1)数据竞争(原子性违规和数据损坏)

2)订购问题

3)滥用锁定导致死锁

4)heisenbugs

多线程的任何其他问题?怎么解决

解决方法

埃里克的四个问题清单非常有用.但调试这些问题很困难.

对于僵局,我总是喜欢“水平锁”.基本上,您为每种类型的锁提供一个级别编号.然后要求线程获取单调的锁.

要做成水平锁,你可以声明一个这样的结构:

typedef struct {
   os_mutex actual_lock;
   int level;
   my_lock *prev_lock_in_thread;
} my_lock_struct;

static __tls my_lock_struct *last_lock_in_thread;

void my_lock_aquire(int level,*my_lock_struct lock) {
    if (last_lock_in_thread != NULL) assert(last_lock_in_thread->level < level)
    os_lock_acquire(lock->actual_lock)
    lock->level = level
    lock->prev_lock_in_thread = last_lock_in_thread
    last_lock_in_thread = lock
}

关于水平锁的好处是死锁导致断言的可能性.通过FUNC和LINE的一些额外魔法,你可以确切地知道你的线程做了什么.

对于数据竞争和缺乏同步,目前的情况非常糟糕.有一些静态工具可以尝试识别问题.但误报率很高.

我工作的公司(http://www.corensic.com)有一个名为Jinx的新产品,它积极寻找可以暴露竞争条件的案例.这是通过使用虚拟化技术来控制各种cpu上的线程交错并放大cpu之间的通信来完成的.

看看这个.您可能还有几天免费下载Beta版.

Jinx特别擅长在无锁数据结构中发现错误.它在寻找其他竞争条件方面也做得非常好.什么是酷的,没有误报.如果你的代码测试接近竞争条件,Jinx会帮助代码走坏路.但如果不存在坏路径,则不会给出错误警告.

猜你在找的C&C++相关文章