我正在尝试运行一个测试程序来查看gdb(backtrace)如何显示调用堆栈。我有以下程序
#include<iostream>
#include<assert.h>
void fun2()
{
assert(0);
}
void fun1()
{
fun2();
}
int main()
{
fun1();
return 0;
}
我做了以下事情:
g++ -g dump.cpp -o out
./out
out: dump.cpp:16: void fun2(): Assertion `0' failed.
Abort (core dumped)
gdb out core.28149
(gdb) bt
No stack. //Why does it show no stack here
我期待它将调用堆栈显示为:
fun2
fun1
main
编辑:
我编辑了代码并编译为g++ -g -O0 dump.cpp -o out
但我还是没有筹码
void fun2(int num)
{
int h=23;
if(h*num>100)
{
assert(0);
}
else
{
cout<<"Hello";
}
}
void fun1(int num)
{
{
fun2(num);
}
}
int main()
{
int num;
cin>>num;
fun1(num);
return 0;
}
汇编代码这次显示了fun1,fun2(assert),main的单独代码。但我仍然看到gdb中没有堆栈
答案 0 :(得分:2)
从/ somepath读取符号../tmp / out ...完成。 “/ somepath here / core.30117“不是核心转储:文件格式无法识别
您的核心转储在某种程度上已损坏。实际上它没有被gdb加载,因此输入bt
没有效果。
尝试检查它,这些命令应该为您提供有关核心转储的一些信息:
file core.28149
strings core.28149
答案 1 :(得分:0)
gcc没有理由不优化你的程序
int main()
{
assert(0);
}
要消除所有疑问,请检查生成的程序集。
答案 2 :(得分:0)
请尝试以下操作:
$ clang++ -g -O0 -o dump dump.cpp
$ ./dump
100
Assertion failed: (0), function fun2, file dump.cpp, line 9.
Abort trap (core dumped)
$ gdb --core dump.core
. . .
Core was generated by `dump'.
Program terminated with signal SIGABRT, Aborted.
#0 0x000000080149f6ca in ?? ()
(gdb) file dump
Reading symbols from dump...done.
(gdb) set solib-search-path "/lib:<path>/llvm/lib"
(gdb) bt
#0 0x000000080149f6ca in thr_kill () from /lib/libc.so.7
#1 0x0000000801574149 in abort () from /lib/libc.so.7
#2 0x0000000801556011 in __assert () from /lib/libc.so.7
#3 0x000000000040130a in fun2 (num=100) at dump.cpp:10
#4 0x0000000000401343 in fun1 (num=100) at dump.cpp:20
#5 0x000000000040137e in main () at dump.cpp:27