c - 如何从调试符号中找到已编译的变量/函数地址

标签 c gcc

我找到了以下关于如何拆分编译文件和调试符号的帖子( How to generate gcc debug symbol outside the build target? )。

但是,我在调试文件中找不到任何有用的信息。

例如,

我的 helloWorld 代码是:

#include<stdio.h>

int main(void) {

    int a;
    a = 5;
    printf("The memory address of a is: %p\n", (void*) &a);
    return 0;
}

我跑了gcc -g -o hello hello.c
objcopy --only-keep-debug hello hello.debug
gdb -s main.debug -e main

在gdb中,我试过的任何东西都不会给我任何信息,我找不到它的地址,我找不到主函数地址

例如 :
(gdb) info variables
All defined variables:

Non-debugging symbols:
0x0000000000400618  _IO_stdin_used
0x0000000000400710  __FRAME_END__
0x0000000000600e3c  __init_array_end
0x0000000000600e3c  __init_array_start
0x0000000000600e40  __CTOR_LIST__
0x0000000000600e48  __CTOR_END__
0x0000000000600e50  __DTOR_LIST__
0x0000000000600e58  __DTOR_END__
0x0000000000600e60  __JCR_END__
0x0000000000600e60  __JCR_LIST__
0x0000000000600e68  _DYNAMIC
0x0000000000601000  _GLOBAL_OFFSET_TABLE_
0x0000000000601028  __data_start
0x0000000000601028  data_start
0x0000000000601030  __dso_handle
0x0000000000601038  __bss_start
0x0000000000601038  _edata
0x0000000000601038  completed.6603
0x0000000000601040  dtor_idx.6605
0x0000000000601048  _end

难道我做错了什么?我是否错误地理解了调试文件?有没有办法从保存的调试信息中找出编译变量/函数的地址?

最佳答案

int a是一个堆栈变量,因此它没有固定地址,除非您正在调用该特定函数。此外,对该函数的每次调用都将分配自己的变量。

当我们说“调试符号”时,我们通常指的是函数和全局变量。在这种情况下,局部变量不是“符号”。事实上,如果您在启用优化的情况下进行编译 int a几乎肯定会被优化为寄存器变量,因此它根本没有地址,除非您通过执行 some_function(&a) 强制将其写入内存。或类似。

您可以找到main的地址只需写信 print main在 GDB 中。这是因为函数出现在值上下文中时会隐式转换为 C 中的指针,而 GDB 的 print使用 C 语义。

关于c - 如何从调试符号中找到已编译的变量/函数地址,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36726498/

相关文章:

c - 宏扩展 : Argument with Commas

c - 交换结构

c - 有没有办法在 GCC/Clang 中将变量设置为未初始化?

c - 汇编代码 : logic behind calculating offset into stack

c - 在 C 程序中使用 system ("clear") 命令时出现奇怪的输出

c++ - 检查 C/C++ 中的开放端口

c - 指向 char 的指针,不同的术语

c - 左移且移位计数为负

c++ - 类方法的返回类型推导? C++1y

linux - 如何找到printf(库函数)的堆栈大小?