1.什么是栈帧?
我们知道每一次函数调用都是一个过程。 这个过程我们通⻓称之为:函数的调⽤过程。 这个过程要为函数开辟栈空间,⽤于本次函数的调用中临时变量的保存、现场保护。这块栈空间我们称之为函数栈帧。
2.函数调用的过程
我们先来看一段代码:
#include <stdio.h>
int myadd(int x, int y)
{
int z = x+y;
return z;
}
int main()
{
int a = 0xaaaaaaaa;
int b = 0xbbbbbbbb;
int c = myadd(a,b);
printf("you should run here!");
return 0;
}
我们发现其实main函数在__tmainCRTStartup 函数中调用的,而__tmainCRTStartup 函数是在 mainCRTStartup 被调⽤的。
在函数调用之前,我们先要了解ebp和esp两个寄存器。ebp:栈底寄存器;esp:栈顶在函数调用的过程中这两个寄存器存放了维护这个栈的栈底和栈顶指针。
⽐如: 调⽤main函数,我们为main函数分配栈帧空间,那么栈帧维护如下:
ebp存放了指向函数栈帧栈底的地址; esp存放了指向函数栈帧栈顶的地址。
当我们要详细研究函数调用过程,必须得对应汇编代码。
1. 从main函数的地⽅开始,要展开main函数的调用就得为main函数创建栈帧,那我们先来看 main函数栈帧的创建。
接下来是Add函数的调⽤用。,参数传递过程:
执⾏call指令的时候按F11,来到了这⾥:
再按F11就进入Add函数的执行代码处:
剩下的是函数返回部分:
以上就是整个函数的调用部分。