Enter:
Enter指令自动为被调用的过程创建堆栈框架,它为局部变量保留堆栈空间并在堆栈中保存基址指针EBP。 该指令执行下面三个动作:
o:在堆栈上压入EBP(push ebp)
o:把EBP设为堆栈框架的基址指针(mov ebp,esp)
o:为局部变量预留空间(sub esp,numbytes)
Enter指令有两个操作数:第一个操作数十常量,用于指定要为局部变量保留出多少堆栈空间;第二个操作数指定过程的嵌套层数(通常层数为0),格式:
enter numbytes,nestinglevel
两个操作数都是立即数。 numbytes总是向上取4的倍数,以使ESP按双字边界地址对齐。 nestinglevel决定了调用过程复制到当前堆栈框架中的堆栈框架指针的数目。
Leave:
Leave指令释放一个过程的堆栈框架。它执行Enter指令相反的操作。把EBP和ESP恢复为过程开始时的值。
如果要是用Enter指令的话, 最好在同一过程的结尾使用Leave指令。否则,为局部变量创建的堆栈空间有可能不会被释放,此外还有可能导致ret指令从堆栈上弹出错误的返回地址。
Enter和Leave举例:
subproc proc
enter 8,0 ;为局部变量保留8字节空间
...
leave
ret
subproc endp
上述enter/leave指令等价于下面指令:
subproc proc
push ebp
mov ebp,esp
sub esp,8
...
mov esp,ebp
pop ebp
ret
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
[ zhengcong3250 发表于 2010-08-01 21:15 ]
LZ在学32位汇编啊!有什么经验没,传授一二呗!我杂看看有点晕呢?感觉东西太多了,记不住啊
[ masmaster 发表于 2010-08-01 21:29 ]
才看几天, 有P经验呀, 呵呵~~