首页 > 解决方案 > 在 GDB 中回溯期间显示的地址是什么?

问题描述

我是 GDB 的新手。我想知道每一帧开头的地址 0xXXXX 到底是什么意思?

在此处输入图像描述

(gdb) bt
#0  g2 (a=4, b=34) at 2.7.c:10
#1  0x0000000008000703 in main (argc=1, argv=0x7ffffffedd48) at 2.7.c:18

这是返回位置的地址还是函数开始的地址?这是代码的适用部分。 在此处输入图像描述

int g2(int a, int b){
    int c = g1(a+3, b-11);
    printf("g2: a = %d, b = %d, c = %d\n", a, b, c);
    return c;
}

int main(int argc, char **argv){
    int a = 5;
    int b = 17;
    int c = g2(a-1, b*2);
    printf("g3: a = %d, b = %d, c = %d\n", a, b, c);
    return 0;
}

标签: cgdb

解决方案


当被调用的代码返回到这个帧时,返回的就是函数内部的返回地址。如果您将代码反汇编为 main ( disas main),您将看到带有地址的 main 代码,其中一个地址将是有问题的地址 (0x8000703),它可能是紧跟在指令之后的call指令。


推荐阅读