> 什么是栈帧
> 栈帧详解
一、什么是栈帧
定义: 栈帧也叫过程活动记录,是编译器用来实现过程/函数调用的一种数据结构。
每一次函数调用都是一个过程,这个过程要为函数开辟空间、分配地址,用于本次函数的调用中临时变量的保存和传递。这块空间我们就称为函数栈帧。
二、栈帧详解
以一个简单代码为例:
转到反汇编:
1.main函数的栈帧分配前:
__tmainCRTStartup是调用main函数之前需要调用的
edp存放了指向函数栈帧栈底的地址
esp存放了指向函数栈帧栈顶的地址
2.main函数的栈帧分配
3.Add函数的调用过程
汇编代码:
栈帧创建过程:
4.函数结束过程:
出栈时会销毁所创建的临时空间。