> 什么是栈帧

> 栈帧详解

一、什么是栈帧
定义: 栈帧也叫过程活动记录,是编译器用来实现过程/函数调用的一种数据结构。
每一次函数调用都是一个过程,这个过程要为函数开辟空间、分配地址,用于本次函数的调用中临时变量的保存和传递。这块空间我们就称为函数栈帧。

二、栈帧详解

以一个简单代码为例:
栈帧——函数的调用过程

转到反汇编:

栈帧——函数的调用过程

1.main函数的栈帧分配前:
栈帧——函数的调用过程

__tmainCRTStartup是调用main函数之前需要调用的
edp存放了指向函数栈帧栈底的地址
esp存放了指向函数栈帧栈顶的地址

2.main函数的栈帧分配
栈帧——函数的调用过程

3.Add函数的调用过程
汇编代码:
栈帧——函数的调用过程

栈帧创建过程:
栈帧——函数的调用过程

4.函数结束过程:
栈帧——函数的调用过程

出栈时会销毁所创建的临时空间。

相关文章: