堆栈平衡

含义

  1. 如果要返回父程序,则当我们在堆栈中进行操作时,一定要保证在RET这条指令执行之前,ESP指向的是我们压入堆栈的地址,也就是堆栈压入的值中途 可能发生变化,但是在函数执行完得和刚开始的保持一致。
  2. 如果通过堆栈传入参数了,那么在函数执行完毕后,要平衡参数导致的堆栈变化。

外平栈与内平栈

外平栈:call 指令后add esp,8
内平栈:调用的函数最后ret 8

ESP(栈顶)寻址

EBP(栈底)寻址

EBP的地址相对固定,不会随着函数执行时对堆栈的操作而改变,可以通过EBP加一个值或减一个值来,ESP的值时不会改变
在这里插入图片描述在push ebp的时候这时的堆栈断点位置就是ESP里的地址,堆栈断点在什么地址,ESP的值就为什么地址

ESP的值时不会改变,所以有了mov ebp,esp这一步为了把esp的地址存放起来,中途调用函数的时候esp的值会发生改变,为了堆栈平衡,所以最后要把esp地址放回去,让调用函数前esp和ebp的值保持一致。

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值