libevent bufferevent pair 死锁

       使用bufferevent pair遇到的死锁问题。产生死锁的demo可下载。

1.死锁现象

读回调线程栈:
(gdb) bt
#0  0x00007ffff7bcbcc0 in pthread_rwlock_wrlock () from /lib64/libpthread.so.0
#1  0x0000000000402982 in ReadCallback (bev=0x63d240, arg=0x7fffffffe240) at libevent_dead_lock.cpp:14
#2  0x0000000000403c3c in bufferevent_run_deferred_callbacks_locked (cb=<optimized out>, arg=0x63d240) at bufferevent.c:167
#3  0x000000000040bb5c in event_process_active_single_queue (base=base@entry=0x63cc60, activeq=0x63d0b0, max_to_process=max_to_process@entry=2147483647, 
    endtime=endtime@entry=0x0) at event.c:1720
#4  0x000000000040c54f in event_process_active (base=0x63cc60) at event.c:1783
#5  event_base_loop (base=0x63cc60, flags=0) at event.c:2006
#6  0x0000000000402cdc in LibEventMgr::Run (this=0x7fffffffe240) at libevent_dead_lock.cpp:53
#7  0x0000000000402b96 in pthread_func1 (arg=0x7fffffffe240) at libevent_dead_lock.cpp:106
#8  0x00007ffff7bc85f0 in start_thread () from /lib64/libpthread.so.0
#9  0x00007ffff72c184d in clone () from /lib64/libc.so.6
#10 0x0000000000000000 in ?? ()

写操作线程栈:
(gdb) bt
#0  0x00007ffff7bcf0a4 in __lll_lock_wait () from /lib64/libpthread.so.0
#1  0x00007ffff7bca444 in _L_lock_1087 () from /lib64/libpthread.so.0
#2  0x00007ffff7bca2b6 in pthread_mutex

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值