本帖最后由 jackz007 于 2021-1-21 00:59 编辑
代码1:code segment public para 'code'
assume cs:code ; 注意这里
main proc far
jmp short begin
d1 dw 01h
d2 dw 02h
d3 dw 03h
d4 dw 04h
begin: mov ax,code
mov ds,ax
mov ax,d1
mov bx,d2
mov cx,d3
mov dx,d4
mov ax,4c00h
int 021h
main endp
code ends
end main
代码 2code segment public para 'code'
assume cs:code,ds:code ; 注意这里
main proc far
jmp short begin
d1 dw 01h
d2 dw 02h
d3 dw 03h
d4 dw 04h
begin: mov ax,code
mov ds,ax
mov ax,d1
mov bx,d2
mov cx,d3
mov dx,d4
mov ax,4c00h
int 021h
main endp
code ends
end main
编译结果,代码1:14B8:0000 EB08 JMP 000A
14B8:0002 0100 ADD [BX+SI],AX
14B8:0004 0200 ADD AL,[BX+SI]
14B8:0006 0300 ADD AX,[BX+SI]
14B8:0008 0400 ADD AL,00
14B8:000A B8B814 MOV AX,14B8
14B8:000D 8ED8 MOV DS,AX
14B8:000F 2E CS: <-- 注意这里
14B8:0010 A10200 MOV AX,[0002] <-- 注意这里
14B8:0013 2E CS: <-- 注意这里
14B8:0014 8B1E0400 MOV BX,[0004] <-- 注意这里
14B8:0018 2E CS: <-- 注意这里
14B8:0019 8B0E0600 MOV CX,[0006] <-- 注意这里
14B8:001D 2E CS: <-- 注意这里
14B8:001E 8B160800 MOV DX,[0008] <-- 注意这里
14B8:0022 B8004C MOV AX,4C00
14B8:0025 CD21 INT 21
编译结果,代码2:14B8:0000 EB08 JMP 000A
14B8:0002 0100 ADD [BX+SI],AX
14B8:0004 0200 ADD AL,[BX+SI]
14B8:0006 0300 ADD AX,[BX+SI]
14B8:0008 0400 ADD AL,00
14B8:000A B8B814 MOV AX,14B8
14B8:000D 8ED8 MOV DS,AX
14B8:000F A10200 MOV AX,[0002] <-- 注意这里
14B8:0012 8B1E0400 MOV BX,[0004] <-- 注意这里
14B8:0016 8B0E0600 MOV CX,[0006] <-- 注意这里
14B8:001A 8B160800 MOV DX,[0008] <-- 注意这里
14B8:001E B8004C MOV AX,4C00
14B8:0021 CD21 INT 21
代码 1 和 代码 2 几乎完全相同,唯一的不同就是 assume 伪指令有差别,从编译结果中看出区别了?代码 1 没有把 ds 寄存器与需要访问数据所在的段进行绑定,编译器只好通过 cs 寄存器来对数据进行索引,而代码 2 把 ds 寄存器与需要访问数据所在的段进行了绑定,情况就如我们所愿了。这就是 assume 伪指令的重要作用。 |