用core dump来调试程序段错误
有的程序可以通过编译, 但在运行时会出现Segment fault(段错误). 这通常都是指针错误引起的.但这不像编译错误一样会提示到文件->行, 而是没有任何信息, 使得我们的调试变得困难起来.
1.在一般Linux系统中,默认是不会产生core dump文件的。通过ulimit -c来查看core dump文件的大小,一般开始是0。
可以设置core文件大小,ulimit -c 1024(kbytes单位)或者ulimit -c unlimited。(注: 使用-c unlimited不限制core文件大小)
2.生成core文件: $ sudo sh -c "ulimit -c unlimited; ./main_arm" # main_arm 是可执行文件名。
3.记得在编译时加上 -g 方便调试,注意不要加上优化选项 -Os(或者-O0 -O1 ....)
4.用gdb查看core文件:
gdb [exec file] [core file]
如:gdb main_arm core
在进入gdb后, 用 bt 或 where 命令查看backtrace以检查发生程序运行到哪里, 来定位core dump的文件行.
5.举例:
- 一个程序cmm_test_tool在运行的时候发生了错误,并生成了一个core文件,如下:
- -rw-r–r– 1 root cmm_test_tool.c
- -rw-r–r– 1 root cmm_test_tool.o
- -rwxr-xr-x 1 root cmm_test_tool
- -rw——- 1 root core.19344
- -rw——- 1 root core.19351
- -rw-r–r– 1 root cmm_test_tool.cfg
- -rw-r–r– 1 root cmm_test_tool.res
- -rw-r–r– 1 root cmm_test_tool.log
- [root@AUTOTEST_SIM2 mam2cm]#
- 就可以利用命令gdb进行查找,参数一是应用程序的名称,参数二是core文件,运行
- gdb cmm_test_tool core.19344结果如下:
- [root@AUTOTEST_SIM2 mam2cm]# gdb cmm_test_tool core.19344
- GNU gdb Red Hat Linux (5.2.1-4)
- Copyright 2002 Free Software Foundation, Inc.
- GDB is free software, covered by the GNU General Public License, and you are
- welcome to change it and/or distribute copies of it under certain conditions.
- Type “show copying” to see the conditions.
- There is absolutely no warranty for GDB. Type “show warranty” for details.
- This GDB was configured as “i386-redhat-linux”…
- Core was generated by `./cmm_test_tool’.
- Program terminated with signal 11, Segmentation fault.
- Reading symbols from /lib/i686/libpthread.so.0…done.
- Loaded symbols for /lib/i686/libpthread.so.0
- Reading symbols from /lib/i686/libm.so.6…done.
- Loaded symbols for /lib/i686/libm.so.6
- Reading symbols from /usr/lib/libz.so.1…done.
- Loaded symbols for /usr/lib/libz.so.1
- Reading symbols from /usr/lib/libstdc++.so.5…done.
- Loaded symbols for /usr/lib/libstdc++.so.5
- Reading symbols from /lib/i686/libc.so.6…done.
- Loaded symbols for /lib/i686/libc.so.6
- Reading symbols from /lib/libgcc_s.so.1…done.
- Loaded symbols for /lib/libgcc_s.so.1
- Reading symbols from /lib/ld-linux.so.2…done.
- Loaded symbols for /lib/ld-linux.so.2
- Reading symbols from /lib/libnss_files.so.2…done.
- Loaded symbols for /lib/libnss_files.so.2
- #0 0×4202cec1 in __strtoul_internal () from /lib/i686/libc.so.6
- (gdb)
- 进入gdb提示符,输入where,找到错误发生的位置和堆栈,如下:
- (gdb) where
- #0 0×4202cec1 in __strtoul_internal () from /lib/i686/libc.so.6
- #1 0×4202d4e7 in strtoul () from /lib/i686/libc.so.6
- #2 0×0804b4da in GetMaxIDFromDB (get_type=2, max_id=0×806fd20) at cmm_test_tool.c:788
- #3 0×0804b9d7 in ConstrctVODProgram (vod_program=0×40345bdc) at cmm_test_tool.c:946
- #4 0×0804a2f4 in TVRequestThread (arg=0×0) at cmm_test_tool.c:372
- #5 0×40021941 in pthread_start_thread () from /lib/i686/libpthread.so.0
- (gdb)
至此,可以看出文件出错的位置是函数 GetMaxIDFromDB ,两个参数分别是2和0×806fd20,这个函数位于源代码的788行,基于此,我们就可以有针对性的找到问题的根源,并加以解决
用core dump来调试程序段错误的更多相关文章
- CORE DUMP生成调试
之前我调试嵌入式linux程序,一般是借助ucontext库,在发生段错误时,直接将错误函数打印出来.有同事建议我使用core dump,于是我今天在嵌入式板卡尝试了core文件的生成,但是也是几经波 ...
- core dump gdb调试
core dump又叫核心转储, 当程序运行过程中发生异常, 程序异常退出时, 由操作系统把程序当前的内存状况存储在一个core文件中, 叫core dump. (linux中如果内存越界会收到SIG ...
- linux (core dump)调试
转自 http://www.cnblogs.com/hazir/p/linxu_core_dump.html Linux Core Dump 当程序运行的过程中异常终止或崩溃,操作系统会将程序当时的内 ...
- linux ulimit的使用,如何产生core文件,调试段错误
---恢复内容开始--- 下面先简单介绍下ulimit命令: 1. limit -a 可以查看系统各种资源的限制,如: core文件大小,数据段的大小等. $ ulimit -a core file ...
- 在Linux上利用core dump和GDB调试segfault
时常会遇到段错误(segfault),调试非常费劲,除了单元测试和基本测试外,有些时候是在在线环境下,没有基本开发和测试工具,这就需要调试的技能.以前介绍过使用strace进行系统调试和追踪<l ...
- 关于内核转储(core dump)的设置方法
原作者:http://blog.csdn.net/wj_j2ee/article/details/7161586 1. 内核转储作用 (1) 内核转储的最大好处是能够保存问题发生时的状态. (2) 只 ...
- 什么是core dump?(转)
什么是Core Dump? 今天调试一个程序, 用到了core dump, 于是写出来, 记于此.什么是Core Dump?Core的意思是内存, Dump的意思是扔出来, 堆出来.开 发和使用Uni ...
- 【转】段错误调试神器 - Core Dump详解
from:http://www.embeddedlinux.org.cn/html/jishuzixun/201307/08-2594.html 段错误调试神器 - Core Dump详解 来源:互联 ...
- 段错误调试神器 - Core Dump详解
一.前言: 有的程序可以通过编译, 但在运行时会出现Segment fault(段错误). 这通常都是指针错误引起的. 但这不像编译错误一样会提示到文件某一行, 而是没有任何信息, 使得我们的调试变得 ...
随机推荐
- PKU 1064 Cable master
题目链接:点击打开链接 有n段绳子,给定n段绳子的长度,单位为厘米.求能够把这些绳子分成k段的最长的段的长度.题目中的trick是最小是1cm,长度不能小于1cm,因此要转换成int来解,然后二分可以 ...
- A Knight's Journey(dfs)
Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 25950 Accepted: 8853 Description Back ...
- POJ3087 Shuffle'm Up(模拟)
题目链接. AC代码如下; #include <iostream> #include <cstdio> #include <cstring> #include &l ...
- BZOJ 1030 [JSOI2007]文本生成器
1030: [JSOI2007]文本生成器 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2624 Solved: 1087[Submit][Stat ...
- 数据结构之顺序栈SqStack
顺序栈SqStack 基本操作 Status InitStack()//构造一个空栈S Status DestroyStack()//销毁栈S,S不再存在 Status ClearStack()//把 ...
- Introduction to Glide, Image Loader Library for Android, recommended by Google
In the passed Google Developer Summit Thailand, Google introduced us an Image Loader Library for And ...
- 2012蓝桥杯本科组C/C++决赛题
星期几 [结果填空] (满分5分) 1949年的国庆节(10月1日)是星期六. 今年()的国庆节是星期一. 那么,从建国到现在,有几次国庆节正好是星期日呢? 只要答案,不限手段! 可以用windows ...
- [Java] JavaMail 简单案例
网易提供了免费的 SMTP / POP3服务,可用于编程测试,详情见 什么是POP3.SMTP和IMAP? 只需要拥有一个网易邮箱账号,并开启该账号的 SMTP / POP3 功能,便可以通过程序发送 ...
- www.chenbowenblog.com 博客地址转移
我的新博客地址是 www.chenbowenblog.com 欢迎来访.
- HDU 1203 I NEED A OFFER! 01背包
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1203 解题思路:简单的01背包,用dp[i]表示花费不超过i时的最大可能性 状态转移方程 dp[i]= ...