我找到了以下关于如何拆分编译文件和调试符号的帖子( 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/