nm命令中的“符号值”是什么意思?

活动演员:

当您列出静态库的符号表(例如)时nm mylib.a,每个符号旁边显示的8位十六进制表示什么意思?那是代码中每个符号的相对位置吗?

另外,多个符号可以具有相同的符号值吗?一堆符号值为00000000的不同符号有什么问题吗?

埃德·卡雷尔(Ed Carrel):

这是我用C编写的代码片段:


#include 
#include 

void foo();

int main(int argc, char* argv[]) {
    foo();
}

void foo() {
   printf("Foo bar baz!");
}

我运行gcc -c foo.c了该代码。以下是nm foo.o表明:

000000000000001b T foo 
0000000000000000 T主
                 U printf

在本例中,我运行的是64位Ubuntu Linux。这就是为什么您在这里看到的8位数十六进制是16位数的原因。:-)

您看到的十六进制数字是目标文件中相关代码相对于本.text.开头的地址(假设我们寻址目标文件中从0x0开始的部分)。如果运行objdump -td foo.o,您将在输出中看到以下内容:

文本段的反汇编:

0000000000000000:
   0:55 push%rbp 1:48 
   89 e5 mov%rsp,%rbp 4:48 
   83 ec 10 sub $ 0x10,%
   rsp 8:89 7d fc mov%edi,-0x4(% rbp)
   b:48 89 75 f0 mov%rsi,-0x10(%rbp)
   f:b8 00 00 00 00 mov $ 0x0,%eax 
  14:e8 00 00 00 00 callq 19 
  19:c9 Leaveq 
  1a:c3 retq 

000000000000001b:
  1b:55 push%rbp 
  1c:48 89 e5 mov%rsp,%rbp 24:48 
  1f:b8 00 00 00 00 mov $ 0x0,%eax
  24:48 89 c7 mov%rax,%rdi
  27:b8 00 00 00 00 mov $ 0x0,%eax 
  2c:e8 00 00 00 00 callq 31 
  31:c9离开q 
  32:c3 retq

请注意,这两个符号与我们从中在符号表中看到的条目正好对齐nm简而言之,如果将此对象文件链接到其他对象文件,则这些地址可能会更改。另外,请记住,callq当您将此文件链接到系统提供的任何libc时在0x2c处都会改变,因为当前这是对printf的不完全调用(它不知道它现在在哪里)。

至于您mylib.a,这里还有更多事情要做。您拥有的文件是一个存档;它包含多个目标文件,每个目标文件都有自己的文本段。例如,这是我的盒子上针对/usr/lib/libm.a的nm的一部分。

e_sinh.o:
0000000000000000ř.LC0 
0000000000000008ř.LC1 
0000000000000010ř.LC2 
0000000000000018ř.LC3 
0000000000000000ř.LC4 
                 ù__expm1 
                 ù__ieee754_exp 
0000000000000000Ť__ieee754_sinh 

e_sqrt.o:
0000000000000000Ť__ieee754_sqrt 

e_gamma_r.o:
0000000000000000ř.LC0 
                 ù__ieee754_exp 
0000000000000000Ť __ieee754_gamma_r 
                 U __ieee754_lgamma_r 
                 U __rint

您会看到多个文本段条目-由第二列中的T表示位于地址0x0,但是每个单独的文件在0x0处只有一个文本段符号。

对于具有多个符号在同一地址休息单独的文件,好像它是可能的也许。毕竟,它只是表中用于确定数据块的位置和大小的条目。但是我不确定。我以前从未见过多个符号引用一节的同一部分。在这方面比我了解更多的人都可以听到。:-)

希望这会有所帮助。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章