汇编 易混淆指令lea offset

Posted dgwblog

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了汇编 易混淆指令lea offset相关的知识,希望对你有一定的参考价值。

lea 是机器指令,offset 是伪指令。

 

 

 

LEA BX, BUFFER ;在实际执行时才会将变量buffer的地址放入bx 

 

MOV BX, OFFSET BUFFER ;在编译时就已经计算出buffer的地址为4300(假设),然后将上句替换为: mov bx,4300

 

 

 

lea可以进行比较复杂的计算,比如lea eax,[esi+ebx*4],把ebx的值*4,加上esi的值,存入eax中。 

mov就不行了。

 

OFFSET只能取得用"数据定义伪指令"定义的变量的有效地址,不能取得一般操作数的有效地址(摘自80x86汇编语言程序设计教程) 

MOV BX,OFFSET [BX+200]这句是错误的 应该用LEA BX,[BX+200]

 

 

 

lea eax,[ebp] 

说明: eax得到ebp指向的堆栈内容的偏移地址, 和寄存器ebp的值是相同的

OFFSET一般用于对数据段操作,

而LEA在指令中算任意寄存器偏移地址

以上是关于汇编 易混淆指令lea offset的主要内容,如果未能解决你的问题,请参考以下文章

汇编中中括号[]作用以及lea和mov指令的区别

总结一下汇编中mov,lea指令的区别

Android 逆向x86 汇编 ( call 子函数调用指令 | jmp 跳转指令 | lea 加载指令 | mov 数据传送指令 )

Android 逆向x86 汇编 ( call 子函数调用指令 | jmp 跳转指令 | lea 加载指令 | mov 数据传送指令 )

汇编寄存器,寻址方式,lea指令解释

汇编寄存器,寻址方式,lea指令解释