本人不才,小白一枚,今天在看书的过程中被汇编、反汇编这两个词搞懵了。赶紧用了搜dog,发现讲的都不是很清楚,这里说一下我的总结。有什么不对的大家见谅。
汇编、反汇编这两个词可做动词,可做名词。
我们先看一个图,一个c程序如何变成一个可执行程序。
(PS:这个图主要为下面讲解用,具体不再讲解,感兴趣的自行查询)
汇编
动词,指的是把汇编语言翻译成机器语言的过程。
就是图中hello.s文件经过汇编器变成二进制hello.o文件的过程。名词,指的便是汇编语言
就是hello.c经过预处理器,再经过编译器生成的hello.s文件。这个文件里的东西就叫汇编程序(汇编语言)。在linux查看.s文件(Ps:源程序为test.c)
我们可以输入gcc -O -S test.c直接生成test.s文件,然后用vim编辑器打开它。
gcc -O -S test.c
vim test.c
可得到:
反汇编
- 动词,指的是由已生成的机器语言(二进制语言)转化为汇编语言的过程,也可以说是汇编的逆向过程。
名词,指的是有机器语言经过反汇编过程生成的汇编语言。
在linux下对利用反汇编器对.o文件进行反汇编。
objdump -d test.o
得到:
我们可以发现,反汇编生成的汇编代码,每一行前面都有一串16进制的数字。这些数字就是每一行汇编代码对应的机器代码。
希望这些对你有所帮助!