版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
看到上面的结果是不是有种老相识的感觉哈,接下来就尝试使用core解决上面问题
core文件
有问题的程序运行后,产生“Segmentation fault”时生成的具有堆栈信息和调试信息的文件。
编译时需要加 -g 选项使程序生成调试信息: gcc -g core_test.c -o core_test
配置生成 core 文件
使用 ulimit -c 查看core开关,如果为0表示关闭,不会生成core文件;
使用 ulimit -c [filesize] 设置core文件大小,当最小设置为4之后才会生成core文件;
使用 ulimit -c unlimited 设置core文件大小为不限制,这是常用的做法;
core文件命名和保存路径
①core文件有默认的名称和路径,但为了方便,我们通常会自己命名和指定保存路径;
②可以通过 /proc/sys/kernel/core_pattern 设置 core 文件名和保存路径,方法如下:
echo “/corefile/core-%e-%p-%t” > /proc/sys/kernel/core_pattern
命名的参数列表:
%p - insert pid into filename 添加pid
%u - insert current uid into filename 添加当前uid
%g - insert current gid into filename 添加当前gid
%s - insert signal that caused the coredump into the filename 添加导致产生core的信号
%t - insert UNIX time that the coredump occurred into filename 添加core文件生成时的unix时间
%h - insert hostname where the coredump happened into filename 添加主机名
%e - insert coredumping executable name into filename 添加命令名。
调试core文件
gdb [exec file] [core file]
上面基础知识讲完了,接下来将实战看看
//test.cpp
#include <iostream>
using namespace std;
int main(){
int*a = NULL;
for(int i =0;i < 11;i++)
a[i] = i;
return 0;
}
首先查看core文件是否开启状态,然后对上面文件进行编译,执行
执行之后,发现当前文件夹里多了一个文件,没错,就是core文件
这时。我们开始gdb的调试
通过第二个框框的内容可以知道,由于执行了a[i]=i产生的错误,这是,查看a和i的值,发现a的地址为0,没有分配地址就直接使用,重新修改源文件,对a进行分配内存重新编译执行。运行ok