函数调用过程:为函数开辟栈空间,用于本次函数的调用中临时变量的保存、现场保护。
我们最熟悉的莫过于程序入口函数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函数,回收空间,完成整个函数调用的过程。