c/c++中的堆栈分析

本文分析了C/C++中函数调用时堆栈的变化,以VS2005环境下编译的代码为例,展示了main函数如何调用fun函数,并详细解释了汇编代码中的堆栈操作,包括参数入栈、调用指令及栈帧建立的过程。
摘要由CSDN通过智能技术生成

这里分析一下c/c++中的函数之间的调用和堆栈的关系。下面的分析是在vs2005的环境里做的。

 c程序:

#include <stdio.h>

int fun(int i,int j)
{
 int re = i + j;
 return re;
}
int main()
{
 fun(1,2);
 return 0;
}

上面的这段程序就不需要多说了吧。重点说一下下面的汇编(如有错误,请给与指正)。首先说明一点,我们在真正写汇编的时候不会像下面这样写的。以main函数为例,以_main:开始并以ret结束。下面的汇编是通过vs直接整出来的,没有处理(O(∩_∩)O哈哈~)。

汇编:

通过上面的内容我们可以发现main里主要是条用了一下自己写的fun函数。

int main() 

 00411A10  push        ebp  ;保存之前的ebp
  00411A11  mov         ebp,esp ;ebp指向esp的位置
  00411A13  sub         esp,0C0h ;将esp减去0c0h。为main中的临时变量预留空间
  00411A19  push        ebx  ;保存ebx
  00411A1A  push        esi  ;保存esi
  00411A1B  push        edi  ;保存edi
  00411A1C  lea         edi,[ebp-0C0h] ;将ebp-0c0h,即原理的sub esp, 0c0h后的esp地址保存到edi中
  00411A22  mov         ecx,30h ;将e

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值