一、介绍
首先是core dump的定义:当程序运行的过程中异常终止或崩溃,操作系统会将程序当时的内存状态记录下来,保存在一个文件中,这种行为就叫做core dump。其实,除了内存信息,还有关键的程序运行状态也会同时dump下来,如寄存器信息、内存管理信息、其他处理器和操作系统状态和信息。
二、开启core dump
在linux中打开core dump有两种方式:
- 使用ulimit开启,判断core dump是否开启的方法,输入ulimit -c,输出的结果为0,core dump是关闭的,一般情况下,core dump是默认关闭的。输入ulimit -c unlimited来开启core dump功能,同时不限制生成的core dump文件的大小。如果需要对core dump文件设置一个大小限制,就将unlimited修改为相应的数字,这里的数字是最大core dump文件的大小
- 在程序中通过调用对应的api,来设置core dump功能
#include <sys/resource.h>
int getrlimit(int resource, struct rlimit *rlim);
int setrlimit(int resource, const struct rlimit *rlim);
下面是一个例子
在本地虚拟机6.828中/home/xxx/lab1/test文件夹下的coredumptest.c文件
我简单设置了一个对空指针的赋值,要注意的是,想要debug的时候能够显示出错代码的行数需要在编译的时候加上-g标识,产生debug信息。
以该文件为例,debug过程为:
gcc -g coredumptest.c -o coredptest
这里产生了两个文件
这里core生成的名字可以通过修改系统设置进行控制,这时再来debug,输入如下命令
gdb ./coredptest core
进入gdb之后输入run运行程序,输入bt定位错误代码的位置。
- 在系统中全局设置core dump