实验一,
任务1-10 对程序task1_1.asm进行汇编、连接,用debug加载、跟踪调试,基于结果,回答问题。1 assume ds:data, cs:code, ss:stack 2 3 data segment 4 db 16 dup(0) ; 预留16个字节单元,初始值均为0 5 data ends 6 7 stack segment 8 db 16 dup(0) ;预留16个字节单元,初始值均为0 9 stack ends 10 code segment 11 start: 12 mov ax, data 13 mov ds, ax 14 15 mov ax, stack 16 mov ss, ax 17 mov sp, 16 ; 设置栈顶 18 19 mov ah, 4ch 20 int 21h 21 code ends 22 end start① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = __076A__, 寄存器(SS) =__076B__, 寄存器(CS) = _076C___ ② 假设程序加载后,code段的段地址是X,则,data段的段地址是__X-2__, stack的段地址是_X-1___。 注:ds=cs-2,ss=cs-1。
任务1-2 对程序task1_2.asm进行汇编、连接,用debug加载、跟踪调试,基于结果,回答问题。
1 assume ds:data, cs:code, ss:stack 2 3 data segment 4 db 4 dup(0) 5 data ends 6 7 stack segment 8 db 8 dup(0) 9 stack ends 10 code segment 11 start: 12 mov ax, data 13 mov ds, ax 14 15 mov ax, stack 16 mov ss, ax 17 mov sp, 8 18 19 mov ah, 4ch 20 int 21h 21 code ends 22 end start① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = __076A__, 寄存器(SS) =__076B__, 寄存器(CS) = __076C__ ② 假设程序加载后,code段的段地址是X,则,data段的段地址是__X-2__, stack的段地址是__X-1__。
任务1-3 对程序task1_3.asm进行汇编、连接,用debug加载、跟踪调试,基于结果,回答问题
1 assume ds:data, cs:code, ss:stack 2 3 data segment 4 db 20 dup(0) 5 data ends 6 7 stack segment 8 db 20 dup(0) 9 stack ends 10 code segment 11 start: 12 mov ax, data 13 mov ds, ax 14 15 mov ax, stack 16 mov ss, ax 17 mov sp, 20 18 19 mov ah, 4ch 20 int 21h 21 code ends 22 end start① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = __076A__, 寄存器(SS) =__076C__, 寄存器(CS) = __076E__ ② 假设程序加载后,code段的段地址是X,则,data段的段地址是_X-4___, stack的段地址是__X-2__。 任务1-4 对程序task1_4.asm进行汇编、连接,用debug加载、跟踪调试,基于结果,回答问题。
1 assume ds:data, cs:code, ss:stack 2 code segment 3 start: 4 mov ax, data 5 mov ds, ax 6 7 mov ax, stack 8 mov ss, ax 9 mov sp, 20 10 11 mov ah, 4ch 12 int 21h 13 code ends 14 15 data segment 16 db 20 dup(0) 17 data ends 18 19 stack segment 20 db 20 dup(0) 21 stack ends 22 end start① 在debug中将执行到line9结束、line11之前,记录此时:寄存器(DS) = _076C___, 寄存器(SS) =__076E__, 寄存器(CS) = 076A___ ② 假设程序加载后,code段的段地址是X____,则,data段的段地址是__X+2__, stack的段地址是_X+4___。
任务1-5 基于上述四个实验任务的实践、观察,总结并回答: ① 对于如下定义的段,程序加载后,实际分配给该段的内存空间大小是 __(N/16)*16__。
1 xxx segment 2 db N dup(0) 3 xxx ends 123② 如果将程序task1_1.asm, task1_2.asm, task1_3.asm, task1_4.asm中,伪指令 end start 改成 end , 哪一个程序仍然可以正确执行?结合实践观察得到的结论,分析、说明原因。 task1_4 可以执行,因为将end stat改成end后,start没有end start与之匹配,于是程序无法从start处开始运行,于是程序从头开始顺序运行,只有程序4开始即为程序段可以运行。
实验任务二 编写一个汇编源程序,实现向内存单元b800:0f00 ~ b800:0f9f连续160字节,依次重复填充十六进制数 据03 04。 Tips: 1. 在实验1的实验任务3中,做过达到同样效果的实验。但当时是通过debug的f命令实现填充的。这一 次,要求编程实现。 在debug中,使用f命令,向内存单元批量填写数据。 -f b800:0f00 0f9f 03 04 把内存单元区间b800:0f00 ~ b800:0f9f连续160个字节,依次重复填充十六进制数据03 04。 2. 编程实现时,注意进制问题、字节顺序问题。编写后,运行程序,如果与实验1的实验任务3结果不一 致,说明程序编写有错误。
1 assume cs:code 2 3 code segment 4 start: 5 mov ax,0b800h 6 mov ds,ax 7 mov bx,0f00h 8 mov cx,80 9 10 s: mov [bx],0403h 11 add bx,2 12 loop s 13 14 mov ah, 4ch 15 int 21h 16 code ends 17 end start
运行结果:
实验任务三 补全之后的代码:
1 assume cs:code 2 data1 segment 3 db 50, 48, 50, 50, 0, 48, 49, 0, 48, 49 ; ten numbers 4 data1 ends 5 6 data2 segment 7 db 0, 0, 0, 0, 47, 0, 0, 47, 0, 0 ; ten numbers 8 data2 ends 9 10 data3 segment 11 db 16 dup(0) 12 data3 ends 13 14 code segment 15 start: 16 mov bx,0 ; 将bx定义为偏移量 17 mov dx,0 ; 将dx定义为寄存器 18 mov cx,10 ; cx 定义为求和次数 19 20 S: mov dx,0 ; 每次清空寄存器 21 mov ax, data1 22 mov ds ,ax 23 add dl, [bx] 24 25 mov ax, data2 26 mov ds ,ax 27 add dl, [bx] 28 29 mov ax, data3 30 mov ds ,ax 31 add [bx],dl 32 33 inc bx 34 loop S 35 36 mov ax,4c00h 37 int 21h 38 39 code ends 40 end start
要求: ① 编程实现把逻辑段data1和逻辑段data2的数据依次相加,结果保存到逻辑段data3中。 ② 在debug中加载、反汇编、调试。在数据项依次相加前,和相加后,分别查看三个逻辑段data1, data2, data3对应的内存空间,确认逐一相加后,结果的确保存在了逻辑段data3中。
原始数据截图:
进行命令的执行
运行后的结果:
实验任务四 已知8086汇编源程序task4.asm代码片段如下。
1 assume cs:code 2 3 data1 segment 4 dw 2, 0, 4, 9, 2, 0, 1, 9 5 data1 ends 6 7 data2 segment 8 dw 8 dup(0) 9 data2 ends 10 11 code segment 12 start: 13 mov ax, data1 14 mov ds, ax 15 mov ax, data2 16 mov ss, ax 17 mov sp, 16 18 19 mov bx, 0 20 mov cx, 8 21 s: 22 push [bx] 23 add bx, 2 24 loop s 25 26 mov ah, 4ch 27 int 21h 28 code ends 29 end start要求: ① 补全程序,实现把逻辑段data1中的8个字数据逆序存储到逻辑段b中。 ② 汇编、连接后,在debug中加载程序,运行到line15程序退出前,使用d命令查看数据段data2对应的 内存空间,确认是否实现题目要求。 实验结果:发现成功完成题目要求
实验任务五 使用任意文本编辑器,录入汇编源程序task5.asm。
1 assume cs:code, ds:data 2 data segment 3 db 'Nuist' 4 db 2, 3, 4, 5, 6 5 data ends 6 7 code segment 8 start: 9 mov ax, data 10 mov ds, ax 11 12 mov ax, 0b800H 13 mov es, ax 14 15 mov cx, 5 16 mov si, 0 17 mov di, 0f00h 18 s: mov al, [si] 19 and al, 0dfh 20 mov es:[di], al 21 mov al, [5+si] 22 mov es:[di+1], al 23 inc si 24 add di, 2 25 loop s 26 27 mov ah, 4ch 28 int 21h 29 code ends 30 end start阅读源程序,从理论上分析源代码的功能,尤其是line15-25,循环实现的功能是什么,逐行理解每条指令的功能。 对程序进行汇编、链接,得到可执行文件,运行并观察结果。 使用debug工具对程序进行调试,执行到程序返回前,即line25执行之后、line27执行之前,观察结果。
源代码中line19的作用是?
使用按位与操作 将字母变成大写
修改line4里5个字节单元的值,重新汇编、链接、运行,观察结果。1 db 2,3,4,5,6 2 --> 改成: 3 db 5 dup(2) 或 db 5 dup(5)基于观察,分析、猜测这里的数值作用是什么。
这里数值的作用应该是改变字母的颜色。
实验任务六 已知8086汇编源程序task6.asm代码片段如下。
1 assume cs:code, ds:data, es:table 2 3 data segment 4 db '1975', '1976', '1977', '1978', '1979' 5 dw 16, 22, 382, 1356, 2390 6 dw 3, 7, 9, 13, 28 7 data ends 8 9 table segment 10 db 5 dup( 16 dup(' ') ) ; 11 table ends 12 13 code segment 14 start: 15 mov ax,data 16 mov ds,ax 17 mov ax,table 18 mov es,ax 19 20 mov bx,0 21 mov bp,0 22 mov si,20 23 mov cx,5 24 25 s: mov ax,ds:[bx] 26 mov es:[bp],ax 27 mov ax,ds:[bx+2] 28 mov es:[bp+2],ax 29 30 mov ax,ds:[si] 31 mov es:[bp+5],ax 32 mov word ptr es:[bp+7],0 33 34 mov ax,ds:[si+10] 35 mov es:[bp+10],ax 36 37 mov ax,ds:[si] 38 mov dl,ds:[si+10] 39 div dl 40 mov es:[bp+13],al 41 mov byte ptr es:[bp+14],0 42 43 add bx,4 44 add bp,16 45 add si,2 46 47 loop s 48 49 mov ah, 4ch 50 int 21h 51 code ends 52 end start
要求: ① 补全程序,实现题目要求,把年份、收入、雇员人数、人均收入,以结构化方式写入table段中。 表格中,每行数据,在逻辑段table中占16个字节,各项数据占据字节大小分配如下。期中,数据之间用 空格间隔。 ② 汇编、连接后,在debug中加载、调试程序。灵活、合理使用u命令、g命令、d命令,显示刚开始逻 辑段table的数据信息,以及,结构化存入数据后,数据段table的数据信息,确认实现题目要求。
运行之后的结果:
Tips: 1. 这道练习任务难度不大,但繁琐。需要你动手实践之前,仔细理清楚各个数据项在table中的布局(偏 移地址)。然后,灵活应用寻址方式和循环,实现数据在内存和内存之间的搬移。 2. 练习时,不考虑小数除法,使用div命令做整除,保留商即可。