函数栈帧就是在调用函数是为其在栈空间上开辟了一段空间,指向过程调用,一个过程调用包括将数据(以过程参数和返回值的形式)和控制从代码的一部分传递到另一部分。
- 栈是向下生长的,从高地址到低地址延伸的
- 每个函数的每次调用的过程,都有它自己独立的一个栈帧结构,用于变量的保存,现场的保护
- 要维护这个栈帧必须使用ebp(栈底指针)和esp(栈顶指针)这俩个寄存器
- cpu如何知道函数运行到哪里——寄存器存放着函数当前正在执行指令的下一条指令
我们以以下代码为例讲解整个函数调用过程:
int my_add(int x, int y)
{
int z = 0;
z = x + y;
return z;
}
int main()
{
int a = 0xaaaaaaaa;
int b = 0xbbbbbbbb;
int ret = my_add(a, b);
printf("you shuold running here!\n");
system("pause");
return 0;
}
一、调用main()函数:
我们从main()函数的地方开始,要展开main()函数的调用就得为main()函数创建栈帧。
- main()函数不是程序的第一个入口,它被start函数调用
- 函数的栈帧被释放,并不是将其内容清空,而是做了一个标记,说明此空间里面的数据无效了。当又有函数被调用形成栈帧是,直接覆盖掉这块空间就好了
<