免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3280 | 回复: 8
打印 上一主题 下一主题

gdb如何调试“锁”相关得程序? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-08-23 16:27 |只看该作者 |倒序浏览
问题:
在gdb调试中,发现某线程中的函数在
pthread_mutex_lock((pthread_mutex_t *) mylock)的时候会阻塞,因工程太大,且是别人的代码,有点无从下手,现在我想用gdb或别得方法来确定是哪个函数在占用这个锁,请问有什么办法?

谢谢各位!

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2006-08-23 22:28 |只看该作者
线程用GDB好像不太行
再现锁的竞争状态非常难

论坛徽章:
0
3 [报告]
发表于 2006-08-24 03:33 |只看该作者
而且调试会影响线程的调度,多半情况无法重现运行时出现的 bug 。

死锁问题必须靠加锁习惯和文档解决。。

论坛徽章:
0
4 [报告]
发表于 2006-08-24 10:45 |只看该作者
谢谢楼上两位,我看了一下阻塞前pthread_mutex_lock()的调用返回错误号,是:Illegal seek!
不解是什么意思啊?是该锁已经被别的线程占用?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
5 [报告]
发表于 2006-08-24 13:51 |只看该作者
不要想着什么都用 gdb 来调试。
printf 有时候是最有效的做法。
推荐 printf 或者 syslog 或者 debug counter

论坛徽章:
0
6 [报告]
发表于 2006-08-24 14:40 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
7 [报告]
发表于 2006-08-24 18:19 |只看该作者
呵呵,谢谢各位,找到死锁的位置&原因了!
还是安心的看看代码比较管用啊!

论坛徽章:
0
8 [报告]
发表于 2006-12-07 14:45 |只看该作者
解决死锁的方法:
1. 认真审查代码,看看lock与unlock是否配对,特别要看看return之前是否忘记了unlock了
2. 可以通过在上锁前、上锁后以及解锁后进行打印或者写日志文件(推荐),来查找死锁的位置。这个时候,计数器是个很好的选择。
3. 看看是否滥用了Linux系统的信号,信号也可能导致死锁。

论坛徽章:
0
9 [报告]
发表于 2012-08-08 08:50 |只看该作者
本帖最后由 fly6 于 2012-08-08 08:55 编辑
flw 发表于 2006-08-24 13:51
不要想着什么都用 gdb 来调试。
printf 有时候是最有效的做法。
推荐 printf 或者 syslog 或者 debug cou ...


1)用printf最好, 将调用加锁的文件和行号打印出来
2)这种方法也不错 http://www.ibm.com/developerwork ... index.html#listing8
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP