Enter的作用相当==push ebp和mov ebp,esp
这后面两句大家很熟悉吧?函数开始一般都是这两句
Leave的作用相当==mov esp,ebp和pop ebp
而这后面这两句也很常见,函数调用完后一般的用到
以上的Enter和leave的作用分别函数开始和结束
Win32汇编中局部变量的使用方法可以解释一个很有趣的现象:在DOS汇编的时候,如果在子程序中的push指令和pop指令不配对,那么返回的时候ret指令从堆栈里得到的肯定是错误的返回地址,程序也就死掉了。但在Win32汇编中,push指令和pop指令不配对可能在逻辑上产生错误,却不会影响子程序正常返回,原因就是在返回的时候esp不是靠相同数量的push和pop指令来保持一致的,而是靠leave指令从保存在ebp中的原始值中取回来的,也就是说,即使把esp改得一塌糊涂也不会影响到子程序的返回,当然,“窍门”就在ebp,把ebp改掉,程序就玩完了
本文介绍了Win32汇编中Enter和Leave指令的作用及局部变量的管理方式。Enter等同于pushebp和movebp,esp,常用于函数开始;Leave等同于movesp,ebp和popebp,用于函数结束。文章还解释了Win32汇编中即使push和pop不配对,也能正常返回的原因。
46

被折叠的 条评论
为什么被折叠?



