您的位置:首页 > 编程语言 > C语言/C++

函数调用过程解析图(函数栈帧)

2017-08-02 23:22 218 查看
函数调用过程:为函数开辟栈空间,用于本次函数的调用中临时变量的保存、现场保护。

我们最熟悉的莫过于程序入口函数main函数,main函数是在__tmainCRTStartup中调用;而__tmainCRTStartup函数是在mainCRTStartup中调用。调用过程中产生的栈空间称之为函数栈帧。

栈帧维护需要esp和ebp寄存器:



esp寄存器存放指向函数栈帧栈顶的指针;ebp寄存器存放指向函数栈帧栈底的指针。

栈空间是从高地址向低地址增长,用来保存函数栈帧。

下来就具体分析一下函数调用过程:

#include <stdio.h>
int Sub(int x, int y)
{
int m = 0;
m = x - y;
return m;
}
int main()
{
int ret = 7;
int tmp = 4;
int t = 0;
t=Sub(ret, tmp);
printf("%d", t);
return 0;


1.对汇编代码进行分析:



2.函数栈帧在内存中的分布情况:



3.函数的返回

函数调用过程对应着调用栈的建立,而函数返回则是进行调用栈的销毁。先将edi,esi,ebx三个寄存器出栈,然后根据记录的call指令的下一条指令的地址找到main函数,回收空间,完成整个函数调用的过程。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息