zoukankan      html  css  js  c++  java
  • 堆栈平衡

    一.什么是堆栈平衡

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

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

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

    第一种情况:push影响堆栈

    比如 call  ...

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

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

              ret.....             

     

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

    ......

     

     堆栈如下:

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

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

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

           第二种:在函数内部添加

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

  • 相关阅读:
    电话号码组合 hash表
    合并区间
    最小路径和 动态规划
    计数排序
    插入排序
    选择排序
    归并排序
    C#中不同程序集(dll)存在相同的命名空间
    生成otp token 脚本
    MySQL 组合索引、唯一组合索引的原理
  • 原文地址:https://www.cnblogs.com/cat47/p/12285209.html
Copyright © 2011-2022 走看看