返回顶部

堆栈平衡

 

一.什么是堆栈平衡

 

含义就是 当函数在一步步执行的时候 一直到ret执行之前,堆栈栈顶的地址 一定要是call指令的下一个地址。

也就是说函数执行前一直到函数执行结束,函数里面的堆栈是要保持不变的。

如果堆栈变化了,那么,要在ret执行前将堆栈恢复成原来的样子。

第一种情况:push影响堆栈

比如 call  ...

函数:mov ...                         (不影响堆栈平衡)

     push.....                      (影响堆栈平衡)

          ret.....             

 

第二种情况:堆栈传递参数

 

......

 

 

 堆栈如下:

 

 因为PUSH 1 PUSH 2 是为了函数传参而准备的 ,当函数执行完成后 ,push1,push2 就都没用了,所以要把堆栈恢复到执行前的位置

两种解决办法 :函数外部处理和内部处理

第一种 :在函数外部添加ADD处理

 

       第二种:在函数内部添加

 

 ret 8 是把 ret 和第一种情况的add 两条指令整合成一条指令,在函数内部完成堆栈平衡。

posted @ 2020-02-08 21:29  cat47  阅读(5125)  评论(0编辑  收藏  举报