textbox

IT博客 联系 聚合 管理
  103 Posts :: 7 Stories :: 22 Comments :: 0 Trackbacks
 
  比如你用local在栈上定义了一个局部变量LocalVar,你知道实际的指令是什么么?一般都差不多像下面的样子:  
  push   ebp  
  mov   esp,   ebp  
  sub   esp,   4  
  现在栈上就有了4各字节的空间,这就是你的局部变量。  
  接下来,你执行mov   LocalVar,   4,那么实际的指令又是什么?是这样:  
  mov   dword   ptr   [ebp-4],   4  
  于是,这个局部变量的“地址”就是ebp-4——显然,它不是一个固定的地址。现在需要将它的“地址”作为参数传给某个函数,你这样写:  
  invoke/call   SomeFunc,   addr   LocalVar  
  实际生成的指令是:  
  lea   eax,   [ebp-4]  
  push   eax  
  call   SomeFunc  
  当然,你也可以写成:  
  mov   eax,   ebp  
  sub   eax,   4  
  push   eax  
  call   SomeFunc  
  看到了,这里多了一条指令。这就是lea的好处。于是,lea又多了一个非常美妙的用途:作简单的算术计算,特别是有了32位指令的增强寻址方式,更是“如虎添翼”:  
  比如你要算EAX*4+EBX+3,结果放入EDX,怎么办?  
  mov   edx,   eax  
  shl   edx,   2  
  add   edx,   ebx  
  add   edx,   3  
  现在用lea一条指令搞定:  
  lea   edx,   [ebx+eax*4+3]


lea的英文解释是:
Load Effective Address.(加入有效地址,开始迷惑效地址是什么???既然是有效地址与mov ax , [address] 又有什么不同呢?其实他们都是等效的。 后来知道实际上是一个偏移量可以是立即数,也可以是经过四则运算的结果,更省空间,更有效率)


posted on 2008-11-26 22:04 零度 阅读(45433) 评论(3)  编辑 收藏 引用

Feedback

# re: 汇编lea 指令与 mov 指令 2013-10-13 22:38 路人乙
mov dword ptr [ebp-4], 4

立即数不能直接mov到内存单元中  回复  更多评论
  

# re: 汇编lea 指令与 mov 指令 2013-12-24 10:39 bravestarr
@路人乙
可以的。  回复  更多评论
  

# re: 汇编lea 指令与 mov 指令 2015-10-22 16:40 陈硕
“显然,它不是一个固定的地址。”
为什么一定要是固定的地址才可以呢?是不是因为MOV指令转换成机器码的需要?  回复  更多评论
  

只有注册用户登录后才能发表评论。