我正在尝试学习更多关于ELF格式的知识,特别是关于节头部分。我刚刚发现了以下内容:
Elf32_Ehdr *ehdr = (Elf32_Ehdr*)p;
Elf32_Shdr *shdr = (Elf32_Shdr *)(p + ehdr->e_shoff);
int shnum = ehdr->e_shnum;
Elf32_Shdr *sh_strtab = &shdr[ehdr->e_shstrndx];
const char *const sh_strtab_p = p + sh_strtab->sh_offset;
for (int i = 0; i < shnum; ++i) {
printf("%2d: %4d '%s'\n", i, shdr[i].sh_name,
sh_strtab_p + shdr[i].sh_name);
}
return 0;
}
现在,我理解这基本上是通过迭代部分表并打印节名称,但我仍然困惑于sh_offset字段。它到底是做什么的?如果e_shstrndx已经指向字符串表节,为什么我们需要sh_offset?