我的程序是这样运行的:
exe -p param1 -i param2 -o param3
它崩溃并生成了一个核心转储文件,core.pid
。
我想分析核心转储文件
gdb ./exe -p param1 -i param2 -o param3 core.pid
但 GDB 将 EXE 文件的参数识别为 GDB 的输入。
在这种情况下如何分析核心转储文件?
最佳答案
您可以通过多种方式将内核与 GDB 一起使用,但将要传递给可执行文件的参数传递给 GDB 并不是使用内核文件的方式。这也可能是您收到该错误的原因。您可以通过以下方式使用核心文件:
gdb <executable> <core-file>
或 gdb <executable> -c <core-file>
或
gdb <executable>
...
(gdb) core <core-file>
使用核心文件时,您不必传递参数。崩溃场景显示在 GDB 中(在 Ubuntu 上使用 GDB 7.1 版进行检查)。
例如:
$ ./crash -p param1 -o param2
Segmentation fault (core dumped)
$ gdb ./crash core
GNU gdb (GDB) 7.1-ubuntu
...
Core was generated by `./crash -p param1 -o param2'. <<<<< See this line shows crash scenario
Program terminated with signal 11, Segmentation fault.
#0 __strlen_ia32 () at ../sysdeps/i386/i686/multiarch/../../i586/strlen.S:99
99 ../sysdeps/i386/i686/multiarch/../../i586/strlen.S: No such file or directory.
in ../sysdeps/i386/i686/multiarch/../../i586/strlen.S
(gdb)
如果要将参数传递给要在 GDB 中调试的可执行文件,请使用 --args
.
例如:
$ gdb --args ./crash -p param1 -o param2
GNU gdb (GDB) 7.1-ubuntu
...
(gdb) r
Starting program: /home/@@@@/crash -p param1 -o param2
Program received signal SIGSEGV, Segmentation fault.
__strlen_ia32 () at ../sysdeps/i386/i686/multiarch/../../i586/strlen.S:99
99 ../sysdeps/i386/i686/multiarch/../../i586/strlen.S: No such file or directory.
in ../sysdeps/i386/i686/multiarch/../../i586/strlen.S
(gdb)
手册页将有助于查看其他 GDB 选项。
最有用的命令是:
-
bt
(回溯) -
info locals
(显示局部变量的值) -
info registers
(显示 CPU 寄存器的值) -
frame X
(更改为堆栈帧X) -
up
和down
(在堆栈帧(调用链)中导航)
关于linux - 当程序具有命令行参数时,如何使用 GDB 分析程序的核心转储文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8305866/