赞
踩
- 1 #include <stdio.h>
- 2
- 3 int func(int param1 ,int param2,int param3)
- 4 {
- 5 int var1 = param1;
- 6 int var2 = param2;
- 7 int var3 = param3;
- 8
- 9 printf("var1=%d,var2=%d,var3=%d",var1,var2,var3);
- 10 return var1;
- 11 }
- 12
- 13 int main(int argc, char* argv[])
- 14 {
- 15 int result = func(1,2,3);
- 16
- 17 return 0;
- 18 }
下面来逐步分析函数的调用过程
1.函数main执行,main各个参数从右向左逐步压入栈中,最后压入返回地址
2.执行第15行,3个参数以从左向右的顺序压入堆栈,及从param3到param1,栈内分布如下图:
- <span style="font-family:Arial Black;">mov 0x8(%ebp),%eax
- mov %eax,-0x4(%ebp)</span>
其中
将[EBP+0x8]地址里的内容赋给EAX,即把param的值赋给EAX,然后把EAX的中的值放到[EBP-4]这个地址里,即把EAX值赋给var1
,完成C代码 int var1 = param1,其他变量雷同。
<span style="font-family:Arial Black;">mov -0x4(%ebp),%eax</span>
最后通过eax寄存器保存函数的返回值;
7.调用执行函数完毕,局部变量var3,var2,var1一次出栈,EBP恢复原值,返回地址出栈,找到原执行地址,param1,param2,param3依次出栈,函数调用执行完毕。图略
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。