汇编网首页登录博客注册
masmaster的学习博客
博客首页博客互动【做检测题】论坛求助

我的博客

个人首页 |  我的文章 |  我的相册 |  我的好友 |  最新访客 |  文章收藏 |  论坛提问 |  友情链接 |  给我留言  
图片载入中
文章收藏

[2010-08-01 14:54] 关于Enter和Leave指令

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
评论次数(2)  |  浏览次数(447)  |  类型(汇编语言笔记) |  收藏此文  | 

[  zhengcong3250   发表于  2010-08-01 21:15  ]

LZ在学32位汇编啊!有什么经验没,传授一二呗!我杂看看有点晕呢?感觉东西太多了,记不住啊

[  masmaster   发表于  2010-08-01 21:29  ]

才看几天, 有P经验呀, 呵呵~~

 
 请输入验证码  (提示:点击验证码输入框,以获取验证码