Windows环境崩溃问题可根据vs调试工具查看,Linux同样可以查看调用堆栈的信息,只是
需要更改Linux设置,使程序崩溃时候产生core文件。然后gdb调试即可。
1产生core文件方法
产生coredump的条件,首先需要确认当前会话的ulimit –c,若为0,则不会产生对应的coredump,需要进行修改和设置。
ulimit -c unlimited (可以产生coredump且不受大小限制),这种设置仅对当前生效,如果想永久生效
那么需要在
/etc/profile中加入以下一行,这将允许生成coredump文件
ulimit-c unlimited
2更改core dump生成路径
因为core dump默认会生成在程序的工作目录,但是有些程序存在切换目录的情况,导致core dump生成的路径没有规律,
所以最好是自己建立一个文件夹,存放生成的core文件。
我建立一个 /data/coredump 文件夹,在根目录data里的coredump文件夹。
调用如下命令
echo /data/coredump/core.%e.%p> /proc/sys/kernel/core_pattern
将更改core文件生成路径,自动放在这个/data/coredump文件夹里。
%e表示程序名, %p表示进程id
3测试生成core文件以及调试

#include <iostream>
#include <stdio.h>
using namespace std;
void core_test1()
{
int i = 0;
//below will call segmentfault
scanf("%d", i);
printf(%d, i);
}
int main()
{
core_test1();
return 0;
}

该程序在core_test1()内部scanf的时候回崩溃,i前面应该加上&
编译的时候带上-g选项,这样才能用gdb调试core

运行后结果显示段错误

进入/data/coredump文件夹可以查看生成的core

可以通过如下命令调试:
./gdb /usr/sbin/xxx core\:exe\:xxx\:pid\:2594\:sig\:11
之后再敲入:bt
示例:

进入gdb环境后,敲core-file /data/coredump/core.ctest.6408

敲bt命令,这是gdb查看back trace的命令

可以看到最近的栈中存储的是调用了IO操作,之前一步是scanf,再往前能看到是
ctest.cpp中第九行 core_test1()函数出错。
到此为止,就是core文件配置生成和调试方法
本文详细介绍如何在Linux环境下配置程序以生成core文件,并利用gdb进行调试的过程。包括设置ulimit以允许生成core文件、指定core文件的保存路径及通过示例程序演示如何调试core文件。
6472

被折叠的 条评论
为什么被折叠?



