Linux下的GNU工具集包括GNU Compiler Collection,也就是大名鼎鼎的GCC,还包括GNU Binutils,即GNU的二进位制工具集。本节主要介绍GNU的二进位制集,对我们在Linux下进行程式码的学习、除错非常有用。
readelf:可以显示elf格式可执行档案的资讯。elf格式是Unix/Linux平台上应用最广泛的二进位制档案之一。
列出elf档案的头资讯:readelf -h a.out

Magic表示幻数,用来指明这个档案是一个elf档案,第一个字节7f是固定的数,45 4c 46分别是elf三个字母的ascii值。
nm:列出目标档案中的符号(函式、变数),常在除错时使用。
用法:nm a.out
size:列出目标档案每一段的大小以及总体的大小。
用法:size a.out
strings:列出目标档案中可打印的字串。
用法:strings test.o
strip:瘦身,用来丢弃目标档案中的全部或者特定的符号,减小档案体积。
strip相当于脱衣服,对于嵌入式系统来说,这个命令必不可少。在strip之后,档案变小了,仍然可以执行,这就就节省了很多空间。strip不仅仅可以针对可执行档案,还能针对目标档案和动态库等。在实际的开发中,经常需要对动态库.so进行strip操作,减少占用空间。而在除错的时候(比如用addr2line),就需要符号了。因此,通常的做法是:strip前的库用来除错,strip后的库用来实际释出,他们两者有对应关系。一旦释出的strip后的库出了问题,就可以找对应的未strip的库来定位。最后啰嗦一句,某某动态库strip前是18M左右,strip后是3M左右,可见,脱脱衣服还是有明显好处的。
用法:strip a.out,注意:strip不要瘦身.o的中间档案,否则会导致无法连结。
file:列出档案的资讯
objcopy:目标档案格式转换
objcopy -O binary a.out a.bin
objcopy -O binary u-boot u-boot.bin
将elf格式的档案转换为二进位制格式。
objdump:主要用来反汇编。
反汇编:把目的码转为汇编程式码的过程,也可以说是把机器语言转换为组合语言程式码、低阶转高阶的意思,常用于软件破解、外挂技术、病毒分析、逆向工程、软件汉化等领域。在此过程中我们可以领悟到软件作者的程式设计思想。总之一句话:软件一切神秘的执行机制全在反汇编程式码里面。目前网络上的许多“免费软件“都跟反汇编息息相关。
objdump -d a.out 输出到终端
objdump -d a.out > test.dis
反汇编bin格式的档案:
objdump -D -b binary -m arm test.bin > test.dis
addr2line:将程式中的地址对应到档名和相应的行号,程式执行出错时,通常会返回一个地址,根据这个地址就可以定位到程式码出错的位置。通常用于定位核心中的错误。
用法:addr2line 地址 -e a.out -f
注意,要想使用addr2line,要求elf档案在编译的时候必须要新增-g引数。






























