我经常使用GDB来调试C/C++程序,而且我对它的工作原理以及它能做什么都很了解.
然而,每隔一段时间我就会遇到一些神秘的问题,我似乎无法让GDB从核心文件中正确加载符号.
目前,我在共享NFS目录中有一个二进制可执行文件.可执行文件肯定是使用-g3标志编译的.可执行文件崩溃并将核心文件转储到我的Linux机器的/ home目录中.
出于某种原因,我无法让GDB从核心文件加载符号.
当我尝试:
$ gdb <executable_file> <core_file>
Run Code Online (Sandbox Code Playgroud)
GDB加载,但我无法获得回溯,并且没有加载调试符号.
如果我运行GDB,然后在GDB提示符下输入core <core file name>它会加载核心文件,我发现核心文件肯定与之前崩溃的二进制可执行文件相关联.但是,GDB报告"无法从内存中读取有效的目标文件图像",因此我无法获得有意义的反向跟踪,并且没有加载调试符号.
有谁知道这可能是什么原因?通常我可以让GDB正确加载核心文件并读入调试符号,但在这种情况下它不起作用.可能是因为二进制可执行文件存储在共享NFS挂载上?
检查你的ulimits.这是混乱的常见原因.截断的核心文件可以使任何形式的gdb检查无效,在大多数情况下你可以读取二进制文件的名称,如果核心文件至少为8k,你可以获得堆栈跟踪.