我的程序是这样运行的:
exe -p param1 -i param2 -o param3
它崩溃并生成一个核心转储文件,core.pid
.
我想通过以下方式分析核心转储文件
gdb ./exe -p param1 -i param2 -o param3 core.pid
但GDB将EXE文件的参数识别为GDB的输入。
在这种情况下如何分析核心转储文件?
您可以通过多种方式将核心与 GDB 结合使用,但将要传递给可执行文件的参数传递给 GDB 并不是使用核心文件的方式。这也可能是您收到该错误的原因。您可以通过以下方式使用 core 文件:
gdb <executable> <core-file>
or gdb <executable> -c <core-file>
or
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
and down
(在堆栈帧(调用链)中导航)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)