Linux调试方法之core dump

最近面试的时候,被问到在linux下程序异常该怎么调试。经过学习才知道有core dump这种东西,随手记录。

core dump介绍

当程序运行的过程中异常终止或崩溃,操作系统会将程序当时的内存状态记录下来,保存在一个文件中,这种行为就叫做Core Dump(中文有的翻译成“核心转储”)。我们可以认为 core dump 是“内存快照”,但实际上,除了内存信息之外,还有些关键的程序运行状态也会同时 dump 下来,例如寄存器信息(包括程序指针、栈指针等)、内存管理信息、其他处理器和操作系统状态和信息。core dump 对于编程人员诊断和调试程序是非常有帮助的,因为对于有些程序错误是很难重现的,例如指针异常,而 core dump 文件可以再现程序出错时的情景。

0.测试程序如下

#include <stdio.h>
int c()
{
    *(char*)0=123;  //0指针赋值会导致segmentation fault
    return 0;
}
int b(int num)
{
    int a = num;
    char s[] = "hello world!";
    printf("%s",s);
    c();
    return 0;
}
int a()
{
    int bbb =111;
    b(bbb);
    return 0;
}
int main(int argc,char *argv[])
{
    a();
    return 0;
}

1.打开core dump

ulimit -c unlimited

2.输出core dump

sudo echo "/tmp/corefile-%e-%p-%t" > /proc/sys/kernel/core_pattern 

3.执行该文件

gcc a.c -g
./a.out

此时执行之后,会在/tmp目录下生成一个corefile-a.out-3151-1523451252的core dump文件

4.在终端输出core dump

gdb ./a.out corefile-a.out-3151-1523451252

core_dump

5.在gdb下输入bt

bt

此时就可以看到调用栈,以及相关的出错内容。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值