#include<stdio.h>
int Add(int a,int b)
{
int z=0;
z=a+b;
return z;
}
int main()
{
int a=3;
int b=5;
int ret=0;
ret=Add(a,b);
return 0;
}
编写一段简单的代码用来理解主函数在调用函数过程中栈空间的使用情况。
将编码转为汇编代码,我们来一步一步分析。
在开始之前,首先要知道esp和ebp的作用:
•esp表示一个指针:该指针永远指向已经使用的栈空间的栈顶。
•ebp表示一个指针:该指针永远指向已经使用的栈空间的栈底。
(栈空间的使用是从高地址向低地址使用的)
•调用mainSRTStartup()函数
在进入主函数之前,会先调用mainSRTSartup()函数。
在mainSRTStartup()函数调用完成后,栈空间的使用情况如下:
•进入main()主函数
可以看到,在进入主函数之后,并没有直接创建变量。
push ebp —>压栈(将ebp的地址存入esp所指向位置的上面4个字节内)
move ebp esp—>让ebp指向esp所指向的位置