免费注册 查看新帖 |

Chinaunix

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

gdb本身的coredump [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-12-15 09:43 |只看该作者 |倒序浏览
10可用积分
程序产生了一个core dump,想用gdb去调试看问题出在什么地方,但是
gdb executable -c core

Loaded symbols for /export/home/lss/lib/libcfg1.so
Core was generated by `executable'.
Program terminated with signal 6, Aborted.
[New process 27818]
[New process 19639]
[New process 28272]
[New process 28188]
[New process 27836]
[New process 27831]
[New process 27829]
[New process 27828]
[New process 27827]
#0  0xffffe410 in __kernel_vsyscall ()
(gdb)bt(where)
奇怪的事情发生了,gdb自己core dump了!
#11 <signal handler called>
#12 0xf73ae04c in _int_free () from /lib/libc.so.6
#13 0xf73ae9d9 in free () from /lib/libc.so.6
#14 0xf799afa1 in operator delete () from /usr/lib/libstdc++.so.6
Memory fault(coredump)

[ 本帖最后由 wenming_1011 于 2009-12-15 09:45 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-12-15 10:18 |只看该作者

回复 #1 wenming_1011 的帖子

自己up

论坛徽章:
0
3 [报告]
发表于 2009-12-15 16:12 |只看该作者
程序产生coredump,如果系统ulimit允许,会产生core文件。
用gdb直接打开这个core文件,并且加载符号表,就可以直接显示堆栈信息和死机的位置。以及当时的变量值。

你要是用gdb直接执行程序的话,可能是你的多线程导致gdb coredump了。

论坛徽章:
0
4 [报告]
发表于 2009-12-15 16:13 |只看该作者

论坛徽章:
0
5 [报告]
发表于 2009-12-15 18:09 |只看该作者

回复 #4 emmoblin 的帖子

你说的出错位置是这里吗?
#0  0xffffe410 in __kernel_vsyscall ()
而堆栈信息又从哪里看呢?

论坛徽章:
0
6 [报告]
发表于 2009-12-17 15:33 |只看该作者
还是自己来回答,也希望有人遇到和我一样的问题能借鉴。gdb里先用list,再用bt或where看出错的地方就不会报coredump了!知其然不知其所以然。不知道为什么使用list之后gdb就不会出coredump了。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
7 [报告]
发表于 2009-12-17 20:16 |只看该作者
原帖由 wenming_1011 于 2009-12-17 15:33 发表
还是自己来回答,也希望有人遇到和我一样的问题能借鉴。gdb里先用list,再用bt或where看出错的地方就不会报coredump了!知其然不知其所以然。不知道为什么使用list之后gdb就不会出coredump了。

这个指定是 GDB 的 bug。

论坛徽章:
0
8 [报告]
发表于 2009-12-21 20:47 |只看该作者
你是不是在源码里定义了一个占用字节数很大的数组?
比如,static int iArray[1024000000];
如果一个程序编译期确定下的变量使用的内存大于ulimit的软限制或硬限制,程序是起不来的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP