1- SI和DI是8086CPU中和bx功能相近的寄存器, SI和DI不能够分成两个8位寄存器来使用, 下面的三组指令实现了相同的功能:
(1) mov bx,0
mov ax,[bx]
(2) mov si,0
mov ax,[si]
(3) mov di,0
mov ax,[di]
或者
(1) mov bx,0
mov ax,[bx + 123]
(2) mov si,0
mov ax,[si + 123]
(3) mov di,0
mov ax,[di + 123]
方法一:
1 ;用寄存器SI和DI实现将字符串'welcome to masm!'复制到它后面的数据区中. 2 assume cs:codesg, ds:datasg 3 datasg segment 4 db 'welcome to masm!' 5 db '................' 6 datasg ends 7 codesg segment 8 start: mov ax,datasg 9 mov ds,ax 10 mov si,0 11 mov di,16 12 13 mov cx,8 14 s: mov ax,[si] 15 mov [di],ax 16 add si,2 17 add di,2 18 loop s 19 20 mov ax,4c00H 21 int 21h 22 codesg ends 23 end start
方法二:
用 [bx(si 或 di) + idata]的方式实现
1 ;用寄存器SI和DI实现将字符串'welcome to masm!'复制到它后面的数据区中. 2 assume cs:codesg, ds:datasg 3 datasg segment 4 db 'welcome to masm!' 5 db '................' 6 datasg ends 7 codesg segment 8 start: mov ax,datasg 9 mov ds,ax 10 mov si,0 11 12 mov cx,8 13 s: mov ax,[si] 14 mov 16[si],ax 15 add si,2 16 loop s 17 18 mov ax,4c00H 19 int 21h 20 codesg ends 21 end start
2- [bx+si] 和 [bx+di]
;(ax)=((ds)*16+(bx)+(si))
;用debug查看内存,如下
;2000:1000 BE 00 06 00 00 00 ......
mov ax,2000H
mov ds,ax
mov bx,1000H
mov si,0
mov ax,[bx + si] ;bx+si = 0 (ax)=00BEH
inc si
mov cx,[bx + si] ;bx+si = 1 (cx)=0600H
inc si
mov di,si
add cx,[bx + di] ;bx+di = 2 (cx)=0600H + 0006H = 0606H
3- [bx+si+idata] 和 [bx+di+idata]
;(ax)=((ds)*16+(bx)+(si)+(idata))
;用debug查看内存,如下
;2000:1000 BE 00 06 00 6A 22 ......
mov ax,2000H
mov ds,ax
mov bx,1000H
mov si,0
mov ax,[bx+2+si] ;(ax)=0600H
inc si
mov cx,[bx+2+si] ;(cx)=6A00H
inc si
mov di,si
mov bx,[bx+2+di] ;(bx)=226AH
总结:内存地址从0开始 bx + 0 表示BE的位置, 由于有高8位和低8位, BE为低8位, 需要组合高8位内容所以[0]中的字为 00BEH