Linux 下使用 gdb 定位 crash 位置

下面这一段代码会出现SEGV错误。

#include <stdio.h>

int foo(void)
{
	int *i = NULL;
	*i = 0;
}

int main(void)
{
	foo();
	return 0;
}


执行后如下:

$ ./foo
段错误 (核心已转储)

但是没有发现 core 文件。

需要设置一下。

ulimit -c unlimited

再次执行生成 core 文件。


使用 gdb 调试:

gdb ./foo ./core
Core was generated by `./foo'.
Program terminated with signal 11, Segmentation fault.
#0 0x00000000004004c4 in foo () at foo.c:6
6 *i = 0;

(gdb) bt
#0 0x00000000004004c4 in foo () at foo.c:6
#1 0x00000000004004d5 in main () at foo.c:11

对于 Linux 系统的崩溃调试,可以使用一些工具来帮助诊断和分析崩溃问题。以下是一些常用的工具: 1. GDB(GNU Debugger):GDB 是一个功能强大的调试器,可以用于分析和调试崩溃的程序。它可以帮助你定位程序崩溃的位置,并查看变量的值、栈信息等。你可以使用 GDB 来调试已经崩溃的程序,或者使用它来运行程序并在崩溃时进行调试。 2. crashcrash 是一个 Linux 内核崩溃分析工具,可以分析内核转储文件(vmcore)或者内核映像文件(vmlinux)。它可以提供有关崩溃的详细信息,如堆栈跟踪、寄存器状态、内存映射等。你可以使用 crash 工具来分析内核崩溃问题。 3. SystemTap:SystemTap 是一个动态跟踪工具,可以帮助你监视和分析 Linux 系统的运行状态。它可以提供丰富的系统调用、函数调用以及内核事件的跟踪功能,用于诊断和调试系统崩溃问题。 4. perf:perf 是 Linux 内核性能分析工具,可以用于收集和分析系统性能数据。它可以帮助你找出系统中的性能瓶颈和问题,并提供详细的性能统计信息。perf 工具可以用于分析崩溃时的系统性能数据,从而帮助你定位问题。 这些工具都是常用的 Linux 调试和分析工具,可以根据具体的崩溃情况选择合适的工具进行使用使用这些工具可能需要一定的专业知识和经验,在使用之前建议先阅读相关文档和教程,以便更好地应用它们来解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值