我的程序是这样运行的:
exe -p param1 -i param2 -o param3
它崩溃并生成了一个核心转储文件core.pid
.
我想通过
gdb ./exe -p param1 -i param2 -o param3 core.pid
但GDB将EXE文件的参数识别为GDB的输入.
在这种情况下,如何分析核心转储文件?
我的程序是这样运行的:
exe -p param1 -i param2 -o param3
它崩溃并生成了一个核心转储文件core.pid
.
我想通过
gdb ./exe -p param1 -i param2 -o param3 core.pid
但GDB将EXE文件的参数识别为GDB的输入.
在这种情况下,如何分析核心转储文件?
可以通过多种方式将core与GDB一起使用,但将要传递给可执行文件的参数传递给GDB并不是使用core文件的方式.这也可能是你出错的原因.您可以通过以下方式使用核心文件:
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
(在堆栈框架(调用链)中导航)