由于之前转载的那个教程最后一篇,代码太长了,虽然注释很详细但我实在看不下去了。。。原文在这里
于是根据《INTEL汇编程序设计第五版》第八章8.2小结以及网上的内容整理如下。
------------------------------------------------------------------分割线---------------------------------------------------------------
创建堆栈框架
总体看来,构建一个堆栈框架包含了以下几个步骤:
- 如果要调用的函数有参数,将参数压入堆栈;
- 用call指令调用子程序;
- 此时子程序开始,将ebp寄存器压入栈:push ebp;
- 将ebp的值设为esp(只是为了方便以后访问参数和局部变量):mov ebp, esp;
- 若有局部变量,将esp的值减去相应的值。假设我们有3个DWORD类型的局部变量,则:sub esp, 12;
- 若有需要保存的寄存器,将要保存的寄存器压栈。
完成上述各个步骤后,堆栈的情况如下图: