函数调用堆栈的理解

被调函数调用前的准备:

       1)主调函数把被调函数的参数由右到左依次压栈

       2)把CALL指令的下一条指令的地址(亦即:返回地址)压栈,同时把EIP修改为被调函数的首地址(通过CALL指令)。

被调函数执行时:

      1)把EBP压入堆栈(PUSH EBP)。

      3)使EBP指向堆栈中原EBP的值(MOV EBP, ESP)。

      3)为被调函数开辟空间(SUB ESB,xxx)。

被调函数执行后:

     1)回收开辟的空间 (MOV ESP, EBP),此时ESP等于EBP。

     2)恢复EBP(POP EBP)。

     3)  执行CALL指令的下一条指令(RET)。

     4)平衡堆栈(ADD ESP,xxx ,亦即回收参数空间)。



---------------------------------------------------------------------------------

其中,如下三条指令:

      PUSH  EBP

      MOV  EBP,  ESP

      SUB  ESP,  立即数

可由一条ENTER指令代替

      ENTER  立即数,  0

---------------------------------------------------------------------------------

EBP - 4  开始是局部变量

*********EBP + 4 是返回地址*********

EBP + 8 开始是函数参数





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值