GDB显示无堆栈

时间:2017-01-09 13:53:28

标签: c++ gdb

我正在尝试运行一个测试程序来查看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中没有堆栈

3 个答案:

答案 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