我知道现代操作系统(如 Linux)并不总是在最初链接的同一地址执行应用程序。但是,当调试器开始环顾四周时,它需要知道原始链接地址和最终执行地址之间的关系。GDB如何计算偏移量?
澄清:我不是在谈论虚拟内存。也就是说,我(我相信是)对虚拟内存的工作原理有一个合理的理解,并且完全在该地址空间中运行。当我从 ELF 转储符号表时,我的符号位于一个位置,但当我从内存中获取它们的地址时,它们位于另一个位置。
在这种特殊情况下,我有一个字符串,它在链接的可执行文件中位于地址 0x0E984141。在该进程的内存转储中,它位于地址 0x0E3F2781。.rodata 部分中的所有内容至少已移动了 0x5919C0。它似乎类似于地址空间布局随机化。