试验1
使用文本编辑器,编写代码,具体如下:
assume cs:code, ds:data
data segment
db 'Nuist'
db 5 dup(2)
data ends
code segment
start:mov ax, data
mov ds, ax
mov ax, 0b800H
mov es, ax
mov cx, 5
mov si, 0
mov di, 0f00h
s: mov al, [si]
and al, 0dfh
mov es:[di], al
mov al, [5+si]
mov es:[di+1], al
inc si
add di, 2
loop s
mov ah, 4ch
int 21h
code ends
end start
运行后可以见到在坐下方出现了绿色的NUIST
![]()
使用debug工具进行反汇编,得到
![]()
让程序运行到0027的位置
![]()
将db 5 dup(2)修改参数后,发现出现的了不同颜色的nuist,说明该数据段控制输出字符的颜色
![]()
试验2
代码书写如下:
assume cs:code, ds:data
data segment
db 23, 50, 66, 71, 35
data ends
code segment
start: mov ax, data
mov ds, ax
mov dl,10
mov cx, 5
mov si, 0
s: mov ax,0
mov al, [si]
div dl
mov bx,ax
mov ah,2
mov dl,bl
or dl,48
int 21h
mov dl,bh
or dl,48
int 21h
mov dl,32
int 21h
inc si
loop s
mov ah, 4ch
int 21h
code ends
end start
运行得到结果
![]()
试验3
代码书写如下:
assume cs:code, ds:data, ss:stack
data segment
dw 0123h, 0456h, 0789h, 0abch, 0defh, 0fedh, 0cbah, 0987h
data ends
stack segment
dw 0, 0, 0, 0, 0, 0, 0, 0
stack ends
code segment
start: mov ax,stack
mov ss, ax
mov sp,16
mov ax, data
mov ds, ax
push ds:[0]
push ds:[2]
pop ds:[2]
pop ds:[0]
mov ax,4c00h
int 21h
code ends
end start
回答以下问题:
- CPU执行程序,程序返回前,data段中的数据为:23 01 56 04 89 07 bc 0a ef 0d ed 0f ba 0c 87 09
- CPU执行程序,程序返回前,cs = 076ch, ss = 076bh,ds = 076ah
- 设程序加载后,code段的地址为X,则data段的段地址为X-2,stack段的段地址为X-1
试验4
代码书写如下:
assume cs:code, ds:data, ss:stack
data segment
dw 0123h, 0456h
data ends
stack segment
dw 0, 0
stack ends
code segment
start: mov ax,stack
mov ss, ax
mov sp,16
mov ax, data
mov ds, ax
push ds:[0]
push ds:[2]
pop ds:[2]
pop ds:[0]
mov ax,4c00h
int 21h
code ends
end start
回答以下问题:
- CPU执行程序,程序返回前,data段中的数据为:23 01 56 04 00 00 00 00 00 00 00 00 00 00 00 00
- CPU执行程序,程序返回前,cs = 076ch, ss = 076bh,ds = 076ah
- 设程序加载后,code段的地址为X,则data段的段地址为X-2,stack段的段地址为X-1
- 对于如下定义的段,如果段中数据占N个字节,则程序加载之后,该段实际占有的空间为 ((N-1)/16+1)*16 字节
name segment
...
name ends
试验5
书写代码如下:
assume cs:code, ds:data, ss:stack
code segment
start: mov ax,stack
mov ss, ax
mov sp,16
mov ax, data
mov ds, ax
push ds:[0]
push ds:[2]
pop ds:[2]
pop ds:[0]
mov ax,4c00h
int 21h
code ends
data segment
dw 0123h, 0456h
data ends
stack segment
dw 0,0
stack ends
end start
回答以下问题:
- CPU执行程序,程序返回前,data段中的数据为:23 01 56 04 00 00 00 00 00 00 00 00 00 00 00 00
- CPU执行程序,程序返回前,cs = 076ah, ss = 076eh,ds = 076dh
- 设程序加载后,code段的地址为X,则data段的段地址为X+3,stack段的段地址为X+4
试验6
根据实验情况,回答问题 “ 如果将(1)、(2)、(3)题中的最后一条伪指令“end start”改为“end”(也就是说不指明程序的入口),则哪个程序仍然可以正确执行?请说明原因。”
- 只有task5(即(3))中的程序可以正常运行,因为程序是默认从开头开始执行,(3)的代码段正好在前面,可以执行,而(1)、(2)的数据段在前面不能执行,会发生错误。
试验7
书写代码如下
assume cs:code
a segment
db 1,2,3,4,5,6,7,8
a ends
b segment
db 1,2,3,4,5,6,7,8
b ends
c1 segment ; 在集成软件环境中,请将此处的段名称由c→改为c1或其它名称
db 8 dup(0)
c1 ends
code segment
start:
mov ax,a
mov ds,ax
mov ax,b
mov es,ax
mov ax,c1
mov ss,ax
mov sp,8
mov cx,4
mov bx,6
s:
mov ax,[bx]
add ax,es:[bx]
push ax
sub bx,2
loop s
mov ah, 4ch
int 21h
code ends
end start
使用debug工具查看C段数据为 02 04 06 08 0a 0c 0e 10 。
![]()
试验8
书写代码如下
assume cs:code
a segment
dw 1,2,3,4,5,6,7,8,9,0ah,0bh,0ch,0dh,0eh,0fh,0ffh
a ends
b segment
dw 8 dup(0)
b ends
code segment
start:
mov ax,a
mov ds,ax
mov ax,b
mov ss,ax
mov sp,16
mov cx,8
mov bx,0
s:
push [bx]
add bx,2
loop s
mov ah, 4ch
int 21h
code ends
end start
使用debug工具查看B段数据为08 00 07 00 06 00 05 00 04 00 03 00 02 00 01 00 。
![]()