资料一 、

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只能取得用”数据定义伪指令”定义的变量的有效地址,不能取得一般操作数的有效地址(摘自80×86汇编语言程序设计教程)
MOV   BX,OFFSET   [BX+200]这句是错误的     应该用LEA   BX,[BX+200]

 

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

 

资料二 、

lea:load effect address. 取得第二个参数的有效地址(也就是去偏移地址)后放入到前面的寄存器(第一个参数)中。
然而lea也同样可以实现mov的操作,例如:
                                  lea edi,[ebx-0ch]
方括号表示存储单元,也就是提取方括号中的数据所指向的内容,然而lea提取内容的地址,这样就实现了把(ebx-0ch)放入到了edi中,但是mov指令是不支持第二个操作数是一个寄存器减去一个数值的。

快三稳赚10大技巧偏移地址, 和寄存器ebp的值是相同的

 

资料二 、

lea:load effect address. 取得第二个参数的有效地址(也就是去偏移地址)后放入到前面的寄存器(第一个参数)中。
然而lea也同样可以实现mov的操作,例如:
                                  lea edi,[ebx-0ch]
方括号表示存储单元,也就是提取方括号中的数据所指向的内容,然而lea提取内容的地址,这样就实现了把(ebx-0ch)放入到了edi中,但是mov指令是不支持第二个操作数是一个寄存器减去一个数值的。