#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所指向的位置

通过分析代码和汇编,本文详细探讨了主函数在调用函数时栈空间的变化,包括esp和ebp指针的作用,以及如何在调用函数前后管理栈空间。在函数调用过程中,为函数开辟了运行时堆栈,执行完后返还给操作系统。
最低0.47元/天 解锁文章
1247

被折叠的 条评论
为什么被折叠?



