From:https://www.zhihu.com/question/40720890?sort=created
汇编中 mov 和 lea 的区别是什么 ?:https://bbs.csdn.net/topics/320046644
lea 是“load effective address”的缩写,
简单的说,
lea指令可以用来将一个内存地址直接赋给目的操作数,
例如:lea eax, [ebx+8] 就是将 ebx+8 这个值直接赋给 eax,而不是把 ebx+8 处的内存地址里的数据赋给 eax。
mov 指令则恰恰相反,
例如:mov eax, [ebx+8] 则是把内存地址为 ebx+8 处的数据赋给 eax。
用你能听懂的话来说:
- lea eax, [eax+2*eax] 的效果是 eax = eax + eax * 2
- mov edx, [ebp+16] 的效果是 edx=*(dword*)(ebp+16)
lea 传的是地址。mov 传的是值
举个例子:
- mov eax, [00400000] 。传的是地址 400000 这个地址里的值,假设 400000 这个地址中的值是 100,那么 eax 寄存器中的值就为 100
- lea eax, [00400000] 。那么 eax 寄存器中的值就是 400000