nm 6在c语言里什么意思啊,nm命令中的“符号值”是什么意思?

小编典典

这是我用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 Tmain

U printf

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

您看到的十六进制数字是目标文件中相关代码相对于本.text.节开头的地址。(假设我们寻址目标文件中从0x0开始的部分)。如果运行objdump -td

foo.o,您将在输出中看到以下内容:

Disassembly of section .text:

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

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 leaveq

32: c3 retq

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

至于您mylib.a,这里还有更多活动。您拥有的文件是一个存档;它包含 多个

目标文件,每个目标文件都有自己的文本段。例如,这是我的盒子上针对/usr/lib/libm.a的nm的一部分。

e_sinh.o:

0000000000000000 r .LC0

0000000000000008 r .LC1

0000000000000010 r .LC2

0000000000000018 r .LC3

0000000000000000 r .LC4

U __expm1

U __ieee754_exp

0000000000000000 T __ieee754_sinh

e_sqrt.o:

0000000000000000 T __ieee754_sqrt

e_gamma_r.o:

0000000000000000 r .LC0

U __ieee754_exp

0000000000000000 T __ieee754_gamma_r

U __ieee754_lgamma_r

U __rint

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

对于具有多个符号在同一地址休息单独的文件,好像它 会

是可能的也许。毕竟,它只是表中用于确定数据块的位置和大小的条目。但是我不确定。我以前从未见过多个符号引用一节的同一部分。任何对此比我有更多知识的人都可以听到。:-)

希望这会有所帮助。

2020-06-07

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值