从这个问题的第二个答案中可以看出,使用节的名称从程序自身内部获取指向程序特定节的指针非常简单。使用libelf
,只需打开程序自己的文件,遍历其中的所有部分(由Elf64_Shdr
结构表示),当部分名称与您想要的部分匹配时停止并使用存储在结构sh_addr
元素中的指针Elf64_Shdr
。在这种情况下,获取想要的指针非常简单,因为它是在 ELF 可执行文件中定义的。
但是,假设您有一个使用动态库的程序,并且您需要获取指向该动态库的一部分的指针。由于其部分的地址是在运行时定义的,如何获得指向动态库部分的指针?
顺便说一句,动态库和主程序本身都有一个同名的部分(这是我需要获得指针的部分)。那么,在这种情况下,这两个具有相同名称的部分是否有可能在内存中相邻存储,所以我只需要获取指向主文件部分的指针(正如我在第一段中解释的那样)并添加一个偏移量到达动态库部分?