一、实验结论

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段:

运行到结束前

 

posted on 2021-11-07 10:37  格比林居佳德  阅读(59)  评论(2)    收藏  举报