在64位的linux终端下通过执行命令gcc –S –o main.s main.c -m32得到对应的汇编代码文件
去掉main.s中以.开头的链接符号得到如下所示的汇编代码:
通过上面的汇编代码我们知道堆栈是向下增长的,函数调用对应的汇编指令为call f。
以下是几条重要的汇编指令,我用课程截图的方式记录了下来:
各寄存器解释:
ebp:堆栈栈底寄存器
esp:堆栈栈顶寄存器
eip:自动跳转下一行运行程序
下面是堆栈变化情况,注意:上面是地地址,堆栈向下增长。
下面是在听课时做的笔记:
总结:
计算机工作原理就是:计算机在堆栈和各类寄存器的帮助下,对数据进行各种操作,从而形成计算结果。
进一步而言就是,具体的寄存器:eax通用寄存器,eip程序计数器,esp:栈顶指针,ebp:栈底指针。在这些寄存器的帮助下,数据和各类跳转信息,在程序栈之中上上下下的移动,从而形成跳转和eax数据累加等操作,把复杂的程序进行拆分成大量的栈操作,从而形成计算结果。