详解汇编语言中中括号[]作用及lea和mov指令的区别

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

现在总结一下:其中牵扯到lea指令,mov指令,[]

一.lea指令:

对于寄存器来说:第二个操作数是寄存器必须要加[],不然报错,这里lea就是取[寄存器]的值,如:

mov eax,2

lea ebx,[eax];执行后ebx=2

mov ebx,eax;等同于上句

lea ebx,eax;编译器报错: error A2070: invalid instruction operands

对于变量来说加不加[]都是一样的效果,都是取变量的地址,相当于指针

如:

num dword 2

lea ebx,num

lea eax,[num]; eax为num的地址,如eax=4206598,随程序不同不同,这时ebx==eax

二.mov指令:

对于变量来说

num dword 2

mov eax,2

mov ebx,num

mov ecx,[num];执行完ebx==ecx==2

对寄存器

mov ebx,eax;ebx==2

mov ecx,[eax];可能会报错,因为这里翻译成汇编是mov ecx,DS:[eax]

总的说来加不加中括号[]的区别就是:

lea对变量没有影响是取地址,对寄存器来说加[]时取值,第二操作数不加[]非法

mov对变量来说没有影响是取值,对寄存器来说是加[]时取地址,第二操作数不加[]是取值

还有一点这里顺便说下,看有的教程说mov指令不支持mov ebx,[eax+2*eax......什么乱七八糟的表达式]归根结底就是对于mov来说当第二个操作数是寄存器的时候如果加上[]就是寻址了....

ps:汇编中中括号的作用[]

在汇编中[]的作用不是单纯的c语言中指针类似,可以分为两种情况,对于变量来说[var]和var作用是一样的

但是对于寄存器来说就有区别了,[eax]是eax的地址(这里是c语言中的指针) 而不加中括号的eax就是c语言中的变量值了,理解有谬误之处望指正

.386

.model flat, stdcall

option casemap :none

include windows.inc

include user32.inc

include kernel32.inc

include masm32.inc

includelib user32.lib

includelib kernel32.lib

includelib masm32.lib

.data

buffer byte "%d",0

num dword 12

.data?

lpszSize db 50 dup(?)

.CODE

START:

lea ebx,[num]

mov eax,[ebx]

mov eax,num

mov eax,[num]

invoke wsprintf,offset lpszSize,offset buffer,eax

invoke MessageBox,NULL, offset lpszSize, offset lpszSize,MB_OK

invoke ExitProcess,0

end START

总结

以上所述是小编给大家介绍的汇编语言中中括号[]作用及lea和mov指令的区别,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

以上是 详解汇编语言中中括号[]作用及lea和mov指令的区别 的全部内容, 来源链接: utcz.com/z/357982.html

回到顶部