您的位置:首页 > 其它

简单了解《栈帧》---函数的调用过程

2017-01-11 22:19 267 查看
简答源代码:(VC.6.0环境下)

#include<stdio.h>

int Add(int x, int y)

{
int z = 0;
z = x + y;
return z;

}

int main()

{
int x = 10;
int y = 20;
int ret=Add(10, 20);
printf("ret = %d\n", ret);
return 0;

}

当程序调试时候,查看【调用堆栈】:我们发现main函数在__tmainCRTStartup函数中调用的,而__tmainCRTStartup函数实在mainCRTStartup中被调用的。

在函数调用过程中要为函数开辟栈空间,用于本次函数的调用中临时变量的保存,现场保护。栈帧的维护是函数调用过程中用ebp,esp两个寄存器存放了维护这个栈的栈底和栈顶指针。

研究函数调用过程时候必须对应反汇编代码。

1,从mian函数开始看,我们先看mian函数的栈帧的创建:



2 下来是Add函数的调用:



之后按F11进入Add函数内部:



3 剩下是函数的返回部分:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: