我们从3个角度高度概括总结函数的栈帧和创建前后到底他做了什么
下来小伙伴们可以结合汇编代码经行分析
1.为形参开辟空间。
2.压入下一条指令的地址,压入前一个函数的栈底的地址为的是函数调用结束时让edp能够回到之前函数的栈底。
3.为函数开辟空间esp经行跳跃,并压入其他寄存器的值,再给开辟好的函数栈帧初始化,为内存分配内存和值
4.将返回值压入寄存器,执行ret指令。
本文深入探讨函数栈帧的创建步骤,包括为形参分配空间、保存返回地址、初始化函数栈及返回值处理。通过汇编代码分析,揭示函数调用背后的内存操作和控制流程。
我们从3个角度高度概括总结函数的栈帧和创建前后到底他做了什么
下来小伙伴们可以结合汇编代码经行分析
1.为形参开辟空间。
2.压入下一条指令的地址,压入前一个函数的栈底的地址为的是函数调用结束时让edp能够回到之前函数的栈底。
3.为函数开辟空间esp经行跳跃,并压入其他寄存器的值,再给开辟好的函数栈帧初始化,为内存分配内存和值
4.将返回值压入寄存器,执行ret指令。
1万+

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