死锁栈信息:
__lll_lock_wait() from
_L_lock_1008
pthread_mutex_lock()
死锁可能情况有两种:
1、自己持有锁再去获取锁
2、两个线程分别持有锁再去获取另一把锁
解决方法步骤:
1、查看所有加锁的地方是否释放锁,防止低级错误
2、查看持有锁后的流程,是否加锁了再去获取锁,特别是有回调函数的时候。可能被忽略。
gdb调试死锁的方法:
gdb
attach pid
thread apply all bt
找到_lll_lock_wait 锁等待的地方。
然后查找该锁被哪个线程锁住了。
例如:
查看哪个线程拥有互斥体
(gdb) print AccountA_mutex
$1 = {__m_reserved = 2, __m_count = 0, __m_owner = 0x2527,
__m_kind = 0, __m_lock
= {__status = 1, __spinlock = 0}}
(gdb) print 0x2527
$2 = 9511
(gdb) print AccountB_mutex
$3 = {__m_reserved = 2, __m_count = 0, __m_owner = 0x2529,
__m_kind = 0, __m_lock = {__status = 1, __spinlock = 0}}
(gdb) print 0x2529
$4 = 9513
(gdb)
从上面的命令中,我们可以看出AccontA_mutex是被线程 5(LWP 9511)加锁(拥有)的,而AccontB_mutex是被线程 3(LWP 9513)加锁(拥有)的。
找出死锁的地方,对应检查代码就可以了。死锁大多是对锁的使用发生交叉所致的,
__lll_lock_wait() from
_L_lock_1008
pthread_mutex_lock()
死锁可能情况有两种:
1、自己持有锁再去获取锁
2、两个线程分别持有锁再去获取另一把锁
解决方法步骤:
1、查看所有加锁的地方是否释放锁,防止低级错误
2、查看持有锁后的流程,是否加锁了再去获取锁,特别是有回调函数的时候。可能被忽略。
gdb调试死锁的方法:
gdb
attach pid
thread apply all bt
找到_lll_lock_wait 锁等待的地方。
然后查找该锁被哪个线程锁住了。
例如:
查看哪个线程拥有互斥体
(gdb) print AccountA_mutex
$1 = {__m_reserved = 2, __m_count = 0, __m_owner = 0x2527,
__m_kind = 0, __m_lock
= {__status = 1, __spinlock = 0}}
(gdb) print 0x2527
$2 = 9511
(gdb) print AccountB_mutex
$3 = {__m_reserved = 2, __m_count = 0, __m_owner = 0x2529,
__m_kind = 0, __m_lock = {__status = 1, __spinlock = 0}}
(gdb) print 0x2529
$4 = 9513
(gdb)
从上面的命令中,我们可以看出AccontA_mutex是被线程 5(LWP 9511)加锁(拥有)的,而AccontB_mutex是被线程 3(LWP 9513)加锁(拥有)的。
找出死锁的地方,对应检查代码就可以了。死锁大多是对锁的使用发生交叉所致的,