EAX, EBX, ECX, EDX, ESI, EDI, EBP, ESP
任何一个32位通用寄存器加上中括号就变成一个间接操作数,寄存器里存放的是数据的地址。
.data
var1 byte 10h
.code
main PROC
nop
mov esi, offset var1 ;将var1变量的起始地址放入esi寄存器。
mov al, [esi] ;给寄存器加中括号,表示取这个地址里面的内容“值”。这就是间接寻址。
mov [esi], bl ;同样的方式出现在目的操作数中(左值),道理一样。
invoke exitprocess, 0
main ENDP
END main
---------------------------------------------------------------------------------------------------------
inc [esi] ;会产生错误,因为操作数必须说明大小。esi只是一个地址的起始位,在1个字节范围内累加,还是在2个字节内累加,还是4字节……?
以下正确写法:
inc byte ptr [esi]
inc word ptr [esi]
inc dword ptr [esi]