一、实验结论
1、实验任务1
-
任务1-1
对程序task1_1.asm进行汇编、连接,用debug加载、跟踪调试,基于结果,回答问题
task1_1.asm
assume ds:data, cs:code, ss:stack data segment db 16 dup(0) ; 预留16个字节单元,初始值均为0 data ends stack segment db 16 dup(0) ;预留16个字节单元,初始值均为0 stack ends code segment start: mov ax, data mov ds, ax mov ax, stack mov ss, ax mov sp, 16 ; 设置栈顶 mov ah, 4ch int 21h code ends end start

① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = _076A_, 寄存器(SS) =
076B, 寄存器(CS) =076C
② 假设程序加载后,code段的段地址是X,则,data段的段地址是X-2 , stack的段地址是X-1 。
- 任务1-2
task1_2.asm
assume ds:data, cs:code, ss:stack data segment db 4 dup(0) ; 预留4个字节单元,初始值均为0 data ends stack segment db 8 dup(0) ; 预留8个字节单元,初始值均为0 stack ends code segment start: mov ax, data mov ds, ax mov ax, stack mov ss, ax mov sp, 8 ; 设置栈顶 mov ah, 4ch int 21h code ends end start

① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = 076A, 寄存器(SS) =076B_, 寄存器(CS) = 076C
② 假设程序加载后,code段的段地址是X,则,data段的段地址是X-2 , stack的段地址是 X-1 。
- 任务1-3
tas1_3.asm
assume ds:data, cs:code, ss:stack
data segment
db 20 dup(0) ; 预留20个字节单元,初始值均为0
data ends
stack segment
db 20 dup(0) ; 预留20个字节单元,初始值均为0
stack ends
code segment
start:
mov ax, data
mov ds, ax
mov ax, stack
mov ss, ax
mov sp, 20 ; 设置初始栈顶
mov ah, 4ch
int 21h
code ends
end start

① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = 076A, 寄存器(SS) =076C_, 寄存器(CS) = 076E
② 假设程序加载后,code段的段地址是X,则,data段的段地址是X-4 , stack的段地址是 X-2 。
- 任务1-4
task1_4.asm
assume ds:data, cs:code, ss:stack code segment start: mov ax, data mov ds, ax mov ax, stack mov ss, ax mov sp, 20 mov ah, 4ch int 21h code ends data segment db 20 dup(0) data ends stack segment db 20 dup(0) stack ends end start

① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = 076C, 寄存器(SS) =076E, 寄存器(CS) = 076A
② 假设程序加载后,code段的段地址是X,则,data段的段地址是X+2 , stack的段地址是 X+4 。
- 任务1-5
基于上述四个实验任务的实践、观察,总结并回答:
① 对于如下定义的段,程序加载后,实际分配给该段的内存空间大小是 ([N/16] +1)*16字节 。
xxx segment db N dup(0) xxx ends
② 如果将程序task1_1.asm, task1_2.asm, task1_3.asm, task1_4.asm中,伪指令 end start 改成end , 哪一个程序仍然可以正确执行?结合实践观察得到的结论,分析、说明原因。
修改后,每个程序都可以加载链接成功,但是在debug中执行只有task1_4.asm可以反汇编成功,原因大致为:删去end 相当于删去了start :的作用,即未向编译器指明程序的入口,程序编译从默认的CS:IP只有task1_4的代码段从该默认地址开始,而其余三个程序则从数据段的定义开始,故而出错。

2、实验任务2
编写一个汇编源程序,实现向内存单元b800:0f00 ~ b800:0f9f连续160字节,依次重复填充十六进制数据03 04。
assume cs :code code segment start: mov ax,0b800h mov ds,ax mov bx,0f00h mov cx,80 s: mov ax,0403h mov [bx],ax add bx,2 loop s mov ah,4ch int 21h code ends end start

3、实验任务3
已知8086汇编源程序task3.asm代码片段,
要求:
① 编程实现把逻辑段data1和逻辑段data2的数据依次相加,结果保存到逻辑段data3中。
② 在debug中加载、反汇编、调试。在数据项依次相加前,和相加后,分别查看三个逻辑段data1,
data2, data3对应的内存空间,确认逐一相加后,结果的确保存在了逻辑段data3中。
assume cs:code data1 segment db 50, 48, 50, 50, 0, 48, 49, 0, 48, 49 ; ten numbers data1 ends data2 segment db 0, 0, 0, 0, 47, 0, 0, 47, 0, 0 ; ten numbers data2 ends data3 segment db 16 dup(0) data3 ends code segment start: mov ax,data1 mov ds,ax mov bx,0 mov ax,data2 add bx,16 mov bx,ax mov ax,data3 add bx,32 mov bx,ax mov cx,10 mov bx,0 s: mov dx,0 add dx,[bx] add dx,[bx+16] mov [bx+32],dx add bx,1 loop s mov ah, 4ch int 21h code ends end start
检查结果:
相加前:

相加后:
4、实验任务4
已知8086汇编源程序task4.asm代码片段,
要求:
① 补全程序,实现把逻辑段data1中的8个字数据逆序存储到逻辑段b中。
② 汇编、连接后,在debug中加载程序,运行到line15程序退出前,使用d命令查看数据段data2对应的
内存空间,确认是否实现题目要求。
assume cs:code data1 segment dw 2, 0, 4, 9, 2, 0, 1, 9 data1 ends data2 segment dw 8 dup(0) data2 ends code segment start:
mov ax,data1
mov ds,ax
mov bx,0
mov cx,8
s: push [bx]
add bx,2
loop s
mov ax,data2
mov ds,ax
mov bx,0
mov cx,8
s2: pop [bx]
add bx,2
loop s2
mov ah, 4ch int 21h code ends end start
data1(076A)逻辑段:

data2逻辑段(076B)为0:

运行结束后:

5、实验任务5
使用任意文本编辑器,录入汇编源程序task5.asm。
task5.asm
assume cs:code, ds:data data segment db 'Nuist' db 2, 3, 4, 5, 6 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
运行结果:
使用debug工具对程序进行调试,使用g命令一次性执行到程序返回前,即ine25执行之后line27执行之前

源代码中line19的作用是:
df16=110111112 line19的作用是将al寄存器中存储的字节的第6位 置为0,其余位保持不变,相当于将不是大写的字符转为大写。此外是line15-25,循环实现了将'NUIST'每个字符(低位)和2、3、4、5、6(高位)结合,存储在显存的某段空间
修改line4里5个字节单元的值,重新汇编、链接、运行,观察结果。
db 2,3,4,5,6 --> 改成: db 5 dup(2) 或 db 5 dup(5)
修改为 db 5 dup(2)后运行:

这里的数字的用途就是和字符组成一个字,存储到显存空间中,是字符显示不同的样式(颜色)。
6、实验任务6
已知8086汇编源程序task6.asm代码片段,
要求:
① 补全程序,将data段中的每行第一个单词从大写->小写。
② 在debug中加载程序,反汇编,执行到line13退出前,用d命令查看data段对应的内存空间,确认每
行第一个单词已经由大写->小写。
assume cs:code, ds:data data segment db 'Pink Floyd ' ; 16字节
db 'JOAN Baez ' ; 16字节
db 'NEIL Young ' ; 16字节
db 'Joan Lennon ' ; 16字节
data ends
code segment
start:
mov ax,data
mov ds,ax
mov cx,4
mov bx,0
s:mov al,[bx]
or al,20h
mov [bx],al
mov al,[bx+1]
or al,20h;
mov [bx+1],al
mov al,[bx+2]
or al,20h;
mov [bx+2],al
mov al,[bx+3]
or al,20h;
mov [bx+3],al
add bx,16
loop s
; ××× mov ah, 4ch int 21h code ends end start
运行之前查看data段

运行到mov ah,4c
查看data段,已变成第一个单词已经变成小写。

7、实验任务7
问题场景描述:
Power idea公司1975年-1979年的基本情况如下:

已知程序task7.asm的代码片段,
要求:
① 补全程序,实现题目要求,把年份、收入、雇员人数、人均收入,以结构化方式写入table段中。表格中,每行数据,在逻辑段table中占16个字节,各项数据占据字节大小分配如下。期中,数据之间用
空格间隔。

② 汇编、连接后,在debug中加载、调试程序。灵活、合理使用u命令、g命令、d命令,显示刚开始逻辑段table的数据信息,以及,结构化存入数据后,数据段table的数据信息,确认实现题目要求。
assume cs:code, ds:data, es:table
data segment
db '1975', '1976', '1977', '1978', '1979'
dw 16,22,382,1356,2390
dw 3, 7, 9, 13, 28
data ends
table segment
db 5 dup( 16 dup(' ') ) ;
table ends
code segment
start:
mov ax,data
mov ds,ax
mov ax,table
mov es,ax
mov bx,0
mov bp,0
mov cx,5
s:mov al,[bx]
mov es:[bp],al
mov al,[bx+1]
mov es:[bp+1],al
mov al,[bx+2]
mov es:[bp+2],al
mov al,[bx+3]
mov es:[bp+3],al
add bx,4
add bp,16
loop s;*****year
mov bp,0
mov cx,5
s1:mov ax,[bx] ;
mov dx,0
mov es:[bp+5],ax
mov es:[bp+7],dx
add bx,2
add bp,16
loop s1;*******shouru
mov bp,0
mov cx,5
s2:mov ax,[bx]
mov es:[bp+10],ax
add bx,2
add bp,16
loop s2;*******renshu
mov bp,0
mov cx,5
s3:mov ax,es:[bp+5]
mov bx,es:[bp+10]
div bl
mov ah,0
mov es:[bp+13],ax
add bp,16
loop s3;*******renjun
mov ah, 4ch
int 21h
code ends
end start
刚开始的table段:

运行到结束前

浙公网安备 33010602011771号