assume cs:codesg
codesg segment
xjazz: mov ax, 2000H ;ax=2000H
mov ds, ax ;ds=ax=2000H
mov bx, 1000H ;bx=1000H
mov ax, [bx] ;将偏移地址1000处存储的数据赋值给AX
;即将物理地址ds:1000处(即2000:1000处)存储的值给AX
inc bx ;bx自增1,即bx++
inc bx ;两次自增完成后bx=1002
mov [bx], ax ;将AX存储的值赋值到物理地址ds:1002处
inc bx
inc bx
mov [bx], ax ;将AX存储的值赋值到物理地址ds:1004处
inc bx ;bx++; bx=1005
mov [bx], al ;将AL的值赋值给物理地址ds:1005
inc bx
mov [bx], al ;将AL的值赋值给物理地址ds:1006
mov ax, 4c00H
int 21H
codesg ends
end xjazz
8086微机采用段地址+偏移地址的方式表示物理地址比如本例中出现的物理地址(表示):2000:1000,2000:1002,2000:1004,2000:1005,2000:1006分别对应着实际物理地址的21000,21002,21004,21005,21006。
再详细解释一下就是冒号前面是段(基)地址,冒号后面是偏移地址,实际表示的物理地址就是把段地址乘以16加偏移地址,16进制下的乘16就是进一位。
inc就是汇编语言中的自增指令,相当于C/C++语言中的"++",这也是为什么C/C++语言下++、–会比+1、-1快的原因,因为当执行自增,自减运算时有直接对应的汇编指令。
ps:作为常识应当知道,编译器编译高级语言写成的程序时,是先将高级语言代码翻译成对应的汇编指令,再将汇编指令转化成对应的机器码执行。