详解汇编语言中中括号[]作用及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指令的区别,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

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

  您可能感兴趣的文章: