变量名加上一个位移就形成了一个直接 - 偏移量操作数。这样可以访问那些没有显式标记的内存位置。假设现有一个字节数组 arrayB:
arrayB BYTE 10h,20h,30h,40h,50h
用该数组作为 MOV 指令的源操作数,则自动传送数组的第一个字节:
mov al,arrayB ;AL = 10h
通过在 arrayB 偏移量上加 1 就可以访问该数组的第二个字节:
mov al,[arrayB+1] ;AL = 20h
如果加 2 就可以访问该数组的第三个字节:
mov al, [arrayB+2] ;AL = 30h
形如 arrayB+1 一样的表达式通过在变量偏移量上加常数来形成所谓的有效地址。有效地址外面的括号表明,通过解析这个表达式就可以得到该内存地址指示的内容。汇编器并不要求在地址表达式之外加括号,但为了清晰明了,建议使用括号。
MASM 没有内置的有效地址范围检查。在下面的例子中,假设数组 arrayB 有 5 个字节,而指令访问的是该数组范围之外的一个内存字节。其结果是一种难以发现的逻辑错误,因此,在检查数组引用时要非常小心:
mov al, [arrayB+20] ; AL = ??
在 16 位的字数组中,每个数组元素的偏移量比前一个多 2 个字节。这就是为什么在下面的例子中,数组 ArrayW 加 2 才能指向该数组的第二个元素:
.data arrayW WORD 100h,200h,300h .code mov ax, arrayW ;AX = 100h mov ax,[arrayW+2] ;AX = 200h
同样,如果是双字数组,则第一个元素偏移量加 4 才能指向第二个元素:
.data arrayD DWORD l0000h,20000h .code mov eax, arrayD ;EAX = 10000h mov eax,[arrayD+4] ;EAX = 20000h
更多...
加载中...