堆栈参数的访问:
在调用函数时,C程序使用标准的方法初始化和访问参数。 C中的函数以序言开始,序言部分的代码保存了EBP寄存器,并使EBP指向当时堆栈的顶部,函数还有可能把一些寄存器入栈, 这些寄存器的值将在函数返回的时候恢复。函数以收尾代码结束,在这部分代码中,EBP被恢复, ret指令从函数返回。如:
subproc proc
push ebp ;序言部分将EBP入栈保存。
然后,将ESP/SP的值设为EBP/BP的值,所以EBP/BP开始作为堆栈的基址指针使用了。
subproc proc
push ebp
mov ebp,esp
这两条指令完成后, 堆栈框架如下图:(用32位寄存器表示)
------------
|parameter1| ;[EBP+12]
------------
|parameter2| ;[EBP+8]
------------
|返回地址 | ;[EBP+4]
------------
| EBP | ;EBP,ESP
------------
函数还会将其他的寄存器入栈保存,但不会改变栈中参数的地址相对于EBP的偏移,随后的代码中,ESP可能会变, 而EBP通常不变。
访问堆栈参数:
在堆栈架构中使用相对基址寻址方式访问堆栈参数,EBP作为基址寄存器,偏移是一个常量。如:
supproc proc
push ebp ;EBP入栈并保存返回地址
mov ebp,esp ;堆栈基址指针
mov eax,[ebp+12] ;第二个参数
add eax,[ebp+8] ;第一个参数
pop ebp ;恢复EBP取得返回地址
ret ;返回
supproc endp
堆栈的清理:
在子例程返回时, 必须用某种方法清除堆栈中的参数, 否则就会导致内存泄露以及堆栈的破坏。
对于这个问题, 简单的方法是在call指令后使用一条add指令给ESP加上一个值,使得ESP指向正确的返回地址。
处理堆栈清理问题的另一种方法是使用stdcall调用约定。 可以在子例程中ret指令后提供一个整数参数以修复ESP的值,这个整数值必须等于堆栈参数消耗的堆栈空间的字数。,比如:
subpurc proc
push ebp
mov ebp,esp
mov eax,[ebp+12]
add eax,[ebp+8]
pop ebp
ret 8 ;消耗了8字节的空间
subproc endp
- [somniumchase] 我一运行就说没有数字 01/01 11:44
- [游客] 为什么啊 08/07 15:36
- [游客] 如果想快一些 就改下面这里 dx值改成1H delay: push ax 04/19 02:53
- [lshhjx] 注释在程序中很重要,楼主不知道吗? 12/08 13:40
- [biaggi] 看不明白,在下還須學習 11/06 08:11
- [游客] 我运行的时候直接显示Unkown filename跳出了- -请问怎么改 06/16 21:44
- [游客] 勿庸置疑,注释是好习惯。与人方便自己方便。 04/12 10:33
- [游客] 老实说,看着真心累呀! 04/07 18:37
- [游客] 很无语,初学者就多看书,不要动不动要别人注释,基础打好了,再自己注释,这样比别人帮你注释好得多 12/17 19:43
- [dgkepu] 初学者:不懂,希望有多点注释带着学习学习! 12/07 20:52
- [游客] windows 7是一个64Bit操作系统,它不兼容DOS,无法识别16Bit系统。重装系统wind 02/28 21:05
- [游客] windows 7是一个64Bit操作系统,它不兼容DOS,无法识别16Bit系统。重装系统wind 02/28 21:05
- [466987333] 你好,高手,我想请教一个问题。 我用的是win7操作系统,32位的,里面没有找masm目录,是不是 12/12 17:30
- [lanfioncc] 那个太高级了。。。我还有点看不懂。。不过谢谢!!! 11/27 11:23
- [yc2010] 实验16中的 table: dw sub1,sub2,sub3,sub4 可不可以改成呢? 09/11 09:08
- [yc2010] mov bl,ah mov bh,0 add bx,bx ----------->这里为 09/07 21:03
- [yc2010] 为什么要add bx,bx呢? 09/07 20:55
- [yc2010] 那是不是像table[bx],ds[bx]....等(内存单元)都是表示一个字节呢? 09/06 21:10
- [masmaster] 杨季文的《80X86汇编语言程序设计教程》 09/01 12:52
- [游客] to masmaster shl左移4位,那al传进来的4,5,6位背景色不就没了. 为什 09/01 11:00