Fork me on Gitee

汇编 易混淆指令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在指令中算任意寄存器偏移地址

posted @ 2019-12-05 23:15  ---dgw博客  阅读(989)  评论(0编辑  收藏  举报