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

这篇博客介绍了汇编语言中堆栈框架的创建、参数访问和清理过程,详细讲解了_stdcall、_cdecl和_fastcall三种函数调用约定的细节,帮助读者深入理解汇编程序设计中的关键概念。
最低0.47元/天 解锁文章
3156

被折叠的 条评论
为什么被折叠?



