函数堆栈调用
一、什么是栈以及特点?
在计算机系统中,栈被定义为一个特殊的容器,用户可以将数据压入栈中,也可以将已经压栈的数据出栈;压栈操作使得栈增大,出栈使得栈减小;栈总是自下增长的,栈顶由称为esp的寄存器进行定位,压栈操作使得栈顶的地址减小,出栈的操使栈顶地址增大;
- 栈的作用?
栈保存了一个函数调用所需要的维护信息,这常常被称为堆栈帧;堆栈帧的一般包括:
- 函数的返回地址和参数;
- 临时变量:包括函数的非静态局部变量以及编译器自动生成的其他临时变量;
- 保存的上下文:包括在函数调用前后需要保持不变的寄存器;
三、函数具体的堆栈调用
- Main(调用方)函数中:
入栈:
- 压入调用main函数的函数maincrtstartup ()函数的栈底指针;
- 开辟main函数的栈帧空间;
- 压入形参以及调用函数;
- 压入回退到调用方时,被调用方的下一条指令的地址;
清栈:
- 清理形参变量地址;
- Sum(被调用方)函数中:
入栈:
- 压入调用sum函数的main函数的栈底指针;
- 开辟sum函数栈帧空间并且初始化0xCCCCCCCC;
- 压入实参;
退栈:
- 清理sum函数的栈帧;
- 回退栈底指针;
- 返回调用方栈帧后下一条指令;
下图为一个完整的程序运行过程: