通过反汇编一个简单的C程序,分析汇编代码理解计算机是如何工作的
1、进入vi编写C语言程序代码,首先必须输入命令vi main,c,其中main.c是文件名。

紧接着按esc键退出编辑状态,再输入一个冒号(shift + 冒号分号那个键),紧跟着输入 wq ;或者按ESC键后输入shift+zz。按回车,即推出vim编辑器回到终端命令窗口
2、使用gcc main.c 进行编译,./a.out进行执行,输入gcc -S -o main.s main.c -m32进行汇编。-S的意思是说只将文件编译成汇编文件,-o 选项表示我们要求编译器给我们输出的可执行文件名为main.s,而main.c是我们的源程序文件

3、使用命令vi main.s进入汇编文件,把语句开头中带有“.”的使用命令“dd”删去,得到纯汇编语言,如果删错了使用命令“u”进行恢复。

各寄存器解释:
ebp:堆栈栈底寄存器
esp:堆栈栈顶寄存器
eip:自动跳转下一行运行程序
先从main代码开始读


计算机工作原理就是:计算机在堆栈和各类寄存器的帮助下,对数据进行各种操作,数据和各类跳转信息,在程序栈之中上上下下的移动,从而形成跳转和eax数据累加等操作,把复杂的程序进行拆分成大量的栈操作,从而形成计算结果。
以下是百度到的各名称的解释

posted on 2017-10-07 22:34  9225王孟亚  阅读(111)  评论(1编辑  收藏  举报