利用GDB调试CORE文件

转载 2012年03月22日 14:45:04

什么是core dump

       core dump又叫核心转储, 当程序运行过程中发生异常, 程序异常退出时, 由操作系统把程序当前的内存状况存储在一个core文件中, 叫core dump。 (linux中如果内存越界会收到SIGSEGV信号,然后就会core dump)。 

       在程序运行的过程中,有的时候我们会遇到Segment fault(段错误)这样的错误。这种看起来比较困难,因为没有任何的栈、trace信息输出。该种类型的错误往往与指针操作相关。往往可以通过这样的方式进行定位。 

造成segment fault,产生core dump的可能原因

1内存访问越界

     a) 由于使用错误的下标,导致数组访问越界

     b) 搜索字符串时,依靠字符串结束符来判断字符串是否结束,但是字符串没有正常的使用结束符

     c) 使用strcpy, strcat, sprintf, strcmp, strcasecmp等字符串操作函数,将目标字符串读/写爆。应该使用strncpy, strlcpy, strncat,strlcat, snprintf, strncmp,strncasecmp等函数防止读写越界。

 2、 多线程程序使用了线程不安全的函数。

 3、 多线程读写的数据未加锁保护。

       对于会被多个线程同时访问的全局数据,应该注意加锁保护,否则很容易造成core dump

 4、 非法指针

       a) 使用空指针

       b) 随意使用指针转换。一个指向一段内存的指针,除非确定这段内存原先就分配为某种结构或类型,或者这种结构或类型的数组,否则不要将它转换为这种结构或类型的指针,而应该将这段内存拷贝到一个这种结构或类型中,再访问这个结构或类型。这是因为如果这段内存的开始地址不是按照这种结构或类型对齐的,那么访问它 时就很容易因为bus error而core dump.

 5、 堆栈溢出

      不要使用大的局部变量(因为局部变量都分配在栈上),这样容易造成堆栈溢出,破坏系统的栈和堆结构,导致出现莫名其妙的错误。  

配置操作系统使其产生core文件

       首先通过ulimit命令查看一下系统是否配置支持了dump core的功能。通过ulimit -c或ulimit -a,可以查看core file大小的配置情况,如果为0,则表示系统关闭了dump core。可以通过ulimit -cunlimited来打开。若发生了段错误,但没有core dump,是由于系统禁止core文件的生成。

 

解决方法:

$ulimit -c unlimited(只对当前shell进程有效)

或在~/.bashrc 的最后加入ulimit -c unlimited(一劳永逸)

# ulimit -c

0

$ ulimit -a 

core file size         (blocks, -c) 0

data seg size          (kbytes, -d) unlimited

file size              (blocks, -f)unlimited

用gdb查看core文件

发生core dump之后, 用gdb进行查看core文件的内容, 以定位文件中引发core dump的行.

gdb [exec file] [core file]

如: gdb ./test test.core

然后使用bt查看调用堆栈。

利用GDB调试多线程core文件

在linux下程序崩溃时,一般会在指定目录下生成一个core文件。core文件仅仅是一个内存映象(同时加上调试信息),主要是用来调试的,接下来我们通过一个案例观察怎么利用GDB调试core文件。在命令...

GDB调试core文件最常用的

  • 2010年04月02日 18:30
  • 45KB
  • 下载

GDB调试core文件详解

一,什么是coredump         我们经常听到大家说到程序core掉了,需要定位解决,这里说的大部分是指对应程序由于各种异常或者bug导致在运行过程中异常退出或者中止,并且在满足一定条...

gdb调试通过core文件找出程序在哪里挂了

开发中有时会遇到程序本身编译没有错,但是就是不能运行的情况,让人纠结,下面通过一个例子说说如何通过通过core文件查看函数调用栈从而找出问题所在。 代码如下: 错误提示: 程序逻辑上并没有错误...

GDB调试core文件(2)

使用gdb和core dump迅速定位段错误 关键字:gdb、段错误、core dump一、什么是core dumpcore:内存、核心的意思; dump:抛出,扔出; core dump:前提:当...

GDB调试core文件样例(如何定位Segment fault)

GDB调试core文件样例(如何定位Segment fault) 分类: Linux/Shell 2010-10-16 12:39 17954人阅读 评论(1) 收藏 举报 ...

GDB调试core文件样例

core dump又叫核心转储, 当程序运行过程中发生异常, 程序异常退出时, 由操作系统把程序当前的内存状况存储在一个core文件中, 叫core dump. (linux中如果内存越界会收到SIG...

Linux学习--gdb调试core文件

cd /BIEE12C/user_projects/domains/bi gdb /BIEE12C/bi/bifoundation/web/bin/sawserver core.10924 (gd...

gdb用法(二) 在Linux下产生并调试core文件

分析核心(core)文件   在程序发生崩溃时,有时可能无法直接运行GDB来进行调试。比如程序可能是在另外一台机器上运行的,或者因为程序对时间比较敏感,所以手动跟踪调试会产生无法接受的延迟等...

arm-linux-gdb+gdbserver环境搭建以及远程调试 及调试core文件

本文主要是描述在调试用gdb 调试coredump文件时出现的问题及解决方法  我编写的一个测试用例 #include int main(void){         int man = 0...
  • lizhiok
  • lizhiok
  • 2015年08月25日 11:33
  • 332
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:利用GDB调试CORE文件
举报原因:
原因补充:

(最多只允许输入30个字)