6、gdb学习之core文件

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/qq_29983883/article/details/102650504

在这里插入图片描述
看到上面的结果是不是有种老相识的感觉哈,接下来就尝试使用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

猜你喜欢

转载自blog.csdn.net/qq_29983883/article/details/102650504
今日推荐