|
发表于 2021-1-20 22:48:58
|
显示全部楼层
本楼为最佳答案
本帖最后由 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
复制代码
代码 2
- code 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 伪指令的重要作用。 |
|