函数调用堆栈、返回值与调用约定

在看文章之前来了解两个指针:
ebp:指向函数栈底的指针
esp:指向函数栈顶栈顶指针

#include<stdio.h>

int sum(int a, int b)
{
	 int temp = 0;
	 temp = a + b;
	 return temp;
}
int main()
{
	 int a = 10;
	 int b = 20;
	 int ret = 0;
	 ret = sum(a, b);
	 printf("ret = %d\n",ret);
	 return 0;
}

一、函数堆栈的建立过程
接下我给程序打个断点,看一下执行时的部分汇编代码是什么样的:
1.main函数第一个大括号到函数第一条语句之间的汇编代码:

    17: int main()
    18: {
00151410  push        ebp  
00151411  mov         ebp,esp  
00151413  sub         esp,0E4h  
00151419  push        ebx  
0015141A  push        esi  
0015141B  push        edi  
0015141C  lea         edi,[ebp-0E4h]  
00151422  mov         ecx,39h  
00151427  mov         eax,0CCCCCCCCh  
0015142C  rep stos    dword ptr es:[edi]  
    19:  int a = 10;
##############################################################################
 这一段汇编程序是干什么的ÿ
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值