微型计算机原理及应用答案汇总

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

CH01微型计算机概述
习题与思考题
1.微型计算机由哪些部件组成?各部件的主要功能是什么?解答:
算术逻辑部件(ALU)微处理
器累加器、寄存器
(CPU)
控制器系统总线:AB、CB、DB
(功能:为CPU和其他部件之间提供数据、地址微型计算机和控制
信息的传输通道)
微机系统输入/输出(I/O)接口:串/并行接口等
(功能:使外部设备和微型机相连)
存储器:只读存储器(ROM)、随机存储器(RAM)
(功能:用来存储信息)
操作系统(OS)系统软件
系统实用程序:汇编、编译、编辑、调试程序等外围设备:打印机、键盘、CRT、磁盘控制器等
(注:CPU的功能--①可以进行算术和逻辑运算;
②可保存少量数据;
③能对指令进行译码并执行规定的动作;
④能和存储器、外设交换数据;
⑤提供整修系统所需要的定时和控制;
⑥可以响应其他部件发来的中断请示。


2.8086/8088 CPU 由哪两部分组成?它们的主要功能各是什么?是如何协调工作的?解答:
总线接口部件(BIU):负责与存储器、I/O端口传送数据
微处理器
(CPU)
执行部件(EU):负责指令的执行
协调工作过程:总线接口部件和执行部件并不是同步工作的,它们按以下流水线技术原则来协调管理:
①每当8086 的指令队列中有两个空字节,或者8088 的指令队列中有一个空字节时,总线接口部件就会自动把指令取到指令队列中。

②每当执行部件准备执行一条指令时,它会从总线接口部件的指令队列前部取出指令的代码,然后用几个时钟周期去执行指令。

在执行指令的过程中,如果必须访问存储器或者输入/输出设备,那么,执行部件就会请求总线接口部件进入总线周期,完成访问内存或者
输入/输出端口的操作;如果此时总线接口部件正好处于空闲状态,那么,会立即响应执行
部件的总线请求。

但有时会遇到这样的情况,执行部件请求总线接口部件访问总线时,总线接口部件正在将某个指令字节取到指令队列中,此时总线接口部件将首先完成这个取指令的操作,然后再去响应执行部件发出的访问总线的请求。

③当指令队列已满,而且执行部件又没有总线访问请求时,总线接口部件便进入空闲状态。

④在执行转移指令、调用指令和返回指令时,由于程序执行的顺序发生了改变,不再是顺序执行下面一条指令,这时,指令队列中已经按顺序装入的字节就没用了。

遇到这种情况,指令队列中的原有内容将被自动消除,总线接口部件会按转移位置往指令队列装入另一个程序段中的指令。

3.8086/8088 CPU 中有哪些寄存器?各有什么用途?标志寄存器F 有哪些标志位?各在
什么情况下置位?解答:
PF、CF。

标志寄存器F 的各标志位置位情况:
· CF:进位标志位。

做加法时出现进位或做减法时出现借位,该标志位置1;否则清0。

·PF:奇偶标志位。

当结果的低8 位中l 的个数为偶数时,该标志位置1;否则清0。

·AF:半进位标志位。

在加法时,当位 3 需向位4 进位,或在减法时位3 需向位 4 借位
时,该标志位就置1;否则清0。

该标志位通常用于对BCD 算术运算结果的调整。

·ZF:零标志位。

运算结果各位都为0 时,该标志位置1,否则清0。

·SF:符号标志位。

当运算结果的最高位为 1 时,该标志位置1,否则清0。

·TF:陷阱标志位(单步标志位)。

当该位置 1 时,将使8086/8088 进入单步指令工作方式。

在每条指令开始执行以前,CPU 总是先测试TF 位是否为1,如果为1,则在本指令执行后将产生陷阱中断,从而执行陷阱中断处理程序。

该程序的首地址由内存的
00004H~00007H 4 个单元提供。

该标志通常用于程序的调试。

例如,在系统调试软件DEBUG 中的T 命令,就是利用它来进行程序的单步跟踪的。

·IF:中断允许标志位。

如果该位置1,则处理器可以响应可屏蔽中断,否则就不能响应可屏蔽中断。

·DF:方向标志位。

当该位置 1 时,串操作指令为自动减量指令,即从高地址到低地址处理字符串;否则串操作指令为自动增量指令。

·OF:溢出标志位。

在算术运算中,带符号的数的运算结果超出了8 位或16 位带符号数所能表达的范围时,即字节运算大于十127 或小于-128 时,字运算大于十
32767 或小于-32768 时,该标志位置位。

4.8086/8088 系统中存储器的逻辑地址和物理地址之间有什么关系?表示的范围各为多少?解答:逻辑地址:段地址:偏移地址
物理地址:也称为绝对地址,由段基址和偏移量两部分构成。

物理地址与系统中的存储空间是一一对应的。

逻辑地址与物理地址两者之间的关系为:物理地址=段地址×16+偏移地址
每个逻辑段的地址范围:0000:0000H~FFFFH;0001:0000H~FFFFH;…;FFFF:0000H~FFFFH;共有232 个地址,但其中有许多地址是重叠的(体现出逻辑地址的优势,可根据需要方便地写出逻辑地址,又不影响其准确的物理地址,逻辑地址与物理地址的关系为多对一的关系)。

物理地址的地址范围:00000H~FFFFFH。

5.已知当前数据段位于存储器的A1000H 到B0FFFH 范围内,问DS=?解答:
A1000H→A100:0000 以A100H 为段地址的64K 物理地址的范围是:偏移地址为0000H~FFFFH,即A100:0000H~A100:FFFFH→A1000H+0000H~A1000H+0FFFFH
=A1000H~B0FFFH,∴DS=A100H。

6.某程序数据段中存有两个字数据1234H 和5A6BH,若已知DS=5AA0H,它们的偏移
地址分别为245AH 和3245H,试画出它们在存储器中的存放情况解答:存放情况如图所
示(左右两侧的写法均可):
5AA0:0000H5AA00H
·
·
·5AA0:245AH5CE5AH ···
···34H 12H 6B H
5AA0:245BH5CE5BH ·
·
5AA0:·
3245H5DC45H
5AA0:3246H5DC46H
·
· ·
7.8086/8088CPU 有哪两种工作模式,它们各有什么特点?
解答:为了适应各种不同的应用场合,8086/8088CPU 芯片可工作在两种不同的工作模式下,即最小模式与最大模式。

所谓最小模式,就是系统中只有一个8086/8088 微处理器,在这种情况下,所有的总
线控制信号,都是直接由这片8086/8088CPU 产生的,系统中的总线控制逻辑电路被减到最少。

该模式适用于规模较小的微机应用系统。

最大模式是相对于最小模式而言的,最大模式用在中、大规模的微机应用系统中。

在最大
模式下,系统中至少包含两个微处理器,其中一个为主处理器,即8086/8088CPU,其它
的微处理器称之为协处理器,它们是协助主处理器工作的。

8.若8086CPU 工作于最小模式,试指出当CPU 完成将AH 的内容送到物理地址为91001H 的存储单元操作时,以下哪些信号应为低电平:M/ IO、RD 、WR 、BHE /S7、DT/ R。

若CPU 完成的是将物理地址91000H 单元的内容送到AL 中,则上述哪些信号应为
低电平。

若CPU 为8088 呢?解答:8086CPU
①存储器写(AH→9100H[0001H])时为低电平的信号:WR 、BHE/S7 。

②存储器读(9100H[0000H]→AL)时为低电平的信号:RD 、DT/ R 。

8088CPU
①存储器写(AH→9100H[0001H])时为低电平的信号:WR 、SS
0(BHE
/S
7) 、M/ IO。

②存储器读(9100H[0000H]→AL)时为低电平的信号:M/ IO、RD 、DT/ R 。

9.什么是指令周期?什么是总线周期?什么是时钟周期?它们之间的关系如何?
解答:指令周期----CPU 执行一条指令所需要的时间称为一个指令周期(Instruction Cycle)。

总线周期----每当CPU 要从存储器或I/O 端口存取一个字节称为一次总线操作,相应于某个总线操作的时间即为一个总线周期(BUS Cycle)。

时钟周期----时钟周期是CPU 处理动作的最小时间单位,其值等于系统时钟频率的倒数,时钟周期又称为T 状态。

它们之间的关系:若干个总线周期构成一个指令周期,一个基本的总线周期由 4 个T 组成,我们分别称为T1~T4,在每个T 状态下,CPU 完成不同的动作。

10. 8086/8088 CPU 有哪些基本操作?基本的读/写总线周期各包含多少个时钟周期?什么情况下需要插入 Tw 周期?应插入多少个 Tw 取决于什么因素?解答:①8086/8088CPU 最小模式下的典型时序有:存储器读写;输入输出;中断响应;系统复位及总线占用操作。

②一个基本的 CPU 总线周期一般包含四个状态T 1、T 2、T 3、T 4 ,即四个时钟周期; ③在存储器和外设速度较慢时,要在T 3之后插入 1 个或几个等待状态T w ;
④应插入多少个 T w 取决于 READY 信号的状态,CPU 没有在 T 3 状态的一开始采样到 READY 信号为低电平,就会在T 3和T 4之间插入等待状态T w ,直到采样到 READY 信号为高电平。

11.试说明 8086/8088 工作在最大和最小模式下系统基本配置的差异。

8086/8088 微机系统中为什么一定要有地址锁存器?需要锁存哪些信息?解答:最大模式配置和最小模式配置有一个主要的差别:①就是在最大模式下,需要用外加电路来对 CPU 发出的控制信号进行变换和组合,以得到对存储器和 I/O 端口的读/写信号及对锁存器(8282)和对总线收发器(8286)等等的控制信号。

8288 总线控制器就是完成上面这些功能的专用芯片。

②为多中断源的需要,常采用中断优先权控制电路(如 Intel8259A )。

8086/8088 系统一定要有地址锁存器――因为高四位地址和状态信号是从同一组引脚上分时送出的,低 16 位地址和数据是从同一组引脚上分时传输的,所以必须把地址信息锁存起来。

需要锁存的信息:地址信号、BHE/S 7 和IO/M (8086 为M/IO )信号进行锁存。

12.试简述 8086/8088 微机系统最小模式下从存器储读数据时的时序过程。

解答:正常的存储器读总线操作占用 4 个时钟周期,通常将它们称为 4 个 T 状态即 T 1~
T 4。

T 1 状态,IO/ M =0,指出要访问存储器。

送地址信号 A 19-0,地址锁存信号 ALE 有效,用来控制 8282 锁存地址。

DT/ R =0,控制 8286/8287 工作在接收状态(读)。

T 2 状态,A 19~A 16 送状态 S 6 ~S 3,AD 7 ~AD 0 浮空,准备接收数据。

同时,RD
=0,表示要进行读操作,而DEN =0 作为 8286/8287 的选通信号,允许进行数据传输。

T 3 状态,从指定的存储单元将数据读出送 AD 7 ~AD 0。

若存储器速度较慢,不能及时读出数据的话,则通过 READY 引脚通知 CPU ,CPU 在 T 3 的前沿采样 READY ,如果 READY =0,则在 T 3 结束后自动插入 1 个或几个等待状态 T W ,
并在每个 T W 的前沿检
测 READY ,等到 READY 变高后,就自动脱离 T W 进入 T 4。

4T 4 状态,CPU 采样数据线,获得数据。

RD 、DEN 等信号失效。

1
2 3
CH02 8086/8088指令系统
习题与思考题
1.假定DS=2000H,ES=2100H,SS=1500H,SI=00A0H,BX=0100H,BP=0010H,数据变量V AL 的偏移地址为0050H,请指出下列指令源操作数是什么寻址方式?源操作数在哪里?如在存储器中请写出其物理地址是多少?
(1)MOV AX,0ABH (2)MOV A X,[100H]
(3)MOV AX,V AL (4)MOV B X,[SI]
(5)MOV AL,V AL[BX] (6)MOV C L,[BX][SI]
[BP][SI],100
(7)MOV V AL[SI],BX (8)MOV 解答:
(1)MOV AX,0ABH 寻址方式:立即寻址;
物理地址:无
(2)MOV AX,[100H]
寻址方式:直接寻址;源操作数在存储器中;物理地址:DS*16+100H=2000H*16+100H=20100H
(3)MOV AX,V AL 寻址方式:直接寻址;源操作数在存储器中;物理地址:DS *16+V AL =
2000H*16+0050H=20050H
(4)MOV BX,[SI] 寻址方式:寄存器间接寻址;源操作数在存储器中;物理地址:DS*16+SI=
2000H*16+00A0H=200A0H
(5)MOV AL,V AL[BX] 寻址方式:变址寻址;源操作数在存储器中;物理地址:DS*16+V AL+BX=
2000H*16+0050H+0100
=20150H
(6)MOV CL,[BX][SI] 寻址方式:基址加变址寻址;源操作数在存储器中;物理地址:DS*16+BX+SI=
2000H*16+0100H+00A0H
=201A0H (7)MOV V AL[SI],BX
寻址方式:寄存器寻址;源操作数在寄存器中;物理地址:无
(8)MOV [BP][SI],100
寻址方式:立即寻址;物理地址:无
2.设有关寄存器及存储单元的内容如下:
DS=2000H ,BX=0100H ,AX=1200H ,SI=0002H ,[20100H]=12H ,
[20101H]=34H ,[20102H]=56H ,[20103]=78H ,[21200]=2AH ,[21201H]=4CH ,[21202H]=0B7H ,[21203H]=65H。

试说明下列各条指令单独执行后相关寄存器或存储单元的内容。

(1)MOV AX,1800H (2)MOV AX,BX
(3)MOV BX,[1200H] (4)MOV DX,1100[BX]
3
对3、6,写出相应标志位的状态)。

(1)ADD V ALUE,BX (2)AND BX,
V ALUE
(3)CMP BX,V ALUE (4)XOR BX,0FFH
(5)DEC BX (6)TEST BX,01H
指令,再执行一条POP 指令,试画出堆栈区和SP 内容变化的过程示意图。

(标出存储单元的地址)解答:
堆栈段SS=0FFA0H 堆栈段SS=0FFA0H
00ADHFFAADH
00AEHFFAAEH 00AEHFFAAEH
00AFHFFAAFH 00AFHFFAAFH
0FFA0:00B0HFFAB0H 0FFA0:00B0HFFAB0H
··
··
··
①初始状态;SP=00B0H②PUSH AX;(AX=8057H)SP=00AEH
堆栈段SS=0FFA0H堆栈段SS=0FFA0H
5.已知程序段如下:
MOV AX,1234H
MOV CL,4
ROL AX,CL
DEC AX
MOV CX,4
MUL CX
试问:(1)每条指令执行后,AX 寄存器的内容是什么?(2)每条指令执行后,CF,SF 及ZF
6
(1)Z=W+(Z+X)(2)Z=W-(X+6)-(R+9)
微型计算机原理习题参考答案
值。

(1)SHR DX,1 (2)SHL DL,1
(3)SAL DH,1 (4)SAR DX,CL (5)ROR DX,CL (6)ROL DL,CL (7)RCR DL,1 (8)RCL DX,CL
8完成了什么功能?
MOV CL ,4 SHL DX ,CL MOV BL ,AH SHL
BL ,CL SHR BL ,CL
OR DL ,BL
解答:DX=2345H ,AX=6780H 。

该程序完成的功能如图所示,将 DX ,AX 拼装成双字后,
左移四位。

DX AX
9.试分析下列程序段:
ADD AX ,BX JNC L2 SUB AX ,BX JNC L3
JMP
SHORTL5
如果 AX 、BX 的内容给定如下: AX
BX
(1)14C6H 80DCH
(2)B568H 54B7H
问该程序在上述情况下执行后,程序转向何处?
解答:(1)AX =AX+BX =14C6H+80DCH =95A2H ;CF =0;无进位,转移至 L2;
(2)方法同(1),略
AX
AX
10.编写一段程序,比较两个5 字节的字符串OLDS 和NEWS,如果OLDS 字符串不同于
NEWS 字符串,则执行NEW_LESS,否则顺序执行。

解答:编程如下,(说明:左测程序为常规编法,两个字符串在一个数据段中;右测的程序要求OLDS 在数据段中,NEWS 在附加段中,利用串操作的指令是可行的)
LEA SI,OLDS;LEA SI,OLDS
LEA DI,NEWS;LEA DI,NEWS
MOV CX,5;MOV CX,5
NEXT:MOV AL,[SI];CLD
MOV BL,[DI];REPE CMPSB
CMP AL,BL;JNZ NEW_LESS
JNZ NEW_LESS;……
INC SI;JMP EXIT
INC DI;NEW_LESS:
LOOP NEXT;……
……EXIT:……
JMP EXIT
NEW_LESS:
……
EXIT:……
11.若在数据段中从字节变量TABLE 相应的单元开始存放了0~15 的平方值,试写出包含有XLAT 指令的指令序列查找N(0~15)的平方。

(设N 的值存放在CL 中)
解答:
MOV BX,OFFSET TABLE;LEA BX,TABLE
MOV CL,N
MOV AL,CL
XLAT
12.有两个双字数据串分别存放在ASC1 和ASC2 中(低字放低地址),求它们的差,结果放在ASC3 中(低字放低地址)。

ASC1 DW 578,400
ASC2 DW 694,12
ASC3 DW ?,?解答:编程如下,
LEA SI,ASC1
LEA DI,ASC2
LEA BX,ASC3
MOV CX,2
CLC
NEXT:MOV AX,[SI] MOV
DX,[DI]
SBB AX,DX
MOV [BX],AX
INC SI
INC SI
INC DI
INC DI
INC BX
INC BX
LOOP NEXT
CH03 汇编语言程序设计
习题与思考题
1.下列语句在存储器中分别为变量分配多少字节空间?并画出存储空间的分配图。

V AR1 DB 10,2
V AR2 DW 5 DUP(?),0
V AR3 DB ‘HOW ARE YOU?’,3 DUP(1,2)
V AR4 DD -1,1,0
解答:字节空间----VAR1:2;V AR2:12;V AR3:20;V AR4:12。

存储空间的分配图:
DS:0000 0A 02 00 00 00 00 00 00—00 00 00 00 00 00 48 4F 0010 57 20 20 41 52 45 20 20—59 4F 55 3F 01 02 01 02
0020 01 02 FF FF FF FF 01 00—00 00 00 00 00 00
2.假定V AR1 和V AR2 为字变量,LAB 为标号,试指出下列指令的错误之处。

(1)ADD V AR1,V AR2 (2)SUB AL,V AR1
(3)JMP LAB[CX] (4)JNZ V AR1
(5)MOV [1000H],100 (6)SHL AL, 4 解答:(1)两个操作数中至少有一个为寄存器;
(2)AL 为字节,V AR1 为字变量,不匹配;
(3)[]中不能用CX,LAB 为标号,非变量;
(4)转向地址应为标号,不能是变量;
(5)目的操作数的类型不确定;
(6)SHL 指令中,当所移位数超过1 时,必须用CL 或CX 来取代所移位数。

3.对于下面的符号定义,指出下列指令的错误。

A1 DB ?
A2 DB 10
K1 EQU 1024
(1)MOV K1,AX(2)MOV A1,AX
(3)CMP A1,A2(4)K1EQU 2048
解答:(1)K1 为常量,不能用MOV 指令赋值;
(2)A1 为字节,AX 为字变量,不匹配;
(3)A1 未定义,无法做比较指令;(4)K1
重新赋值前,必须用PURGE 释放。

4.数据定义语句如下所示:
FIRST DB 90H,5FH,6EH,69H
SECOND DB 5 DUP(?)
THIRD DB 5 DUP(?) 自FIRST 单元开始存放的是一个四字节的十六进制数(低位字节在前),要求:
编一段程序将这个数左移两位后存放到自SECOND 开始的单元,右移两位后存放到自THIRD 开始的单元。

(注意保留移出部分)
解答:
DA TA SEGMENT
FIRST DB90H,5FH,6EH,69H
SECOND DB 5 DUP(?)
THIRD DB5 DUP(?)
DA TA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START:MOV AX,DA TA
MOV DS,AX
LEA SI,FIRST
LEA DI,SECOND
MOV CX,2
CLC
;左移2 位
MOV AX,[SI];AX=5F90H 为低十六位数据
INC SI
INC SI
MOV DX,[SI];DX=696EH 为高十六位数据
PUSH DX;保存原有的高十六位数据PUSH
AX;保存原有的低十六位数据
ROL DX,CL;将高位数据不带进位循环左移两位,即高2 位数据在DL 的低2 位
AND DL,03H;让DL 中仅保存移出的高2 位数据
MOV [DI+4] ,DL;将移出的高2 位数据放入SECOND 中的最高单元中
ROL AX,CL;将低位数据不带进位循环左移两位,即AX 的高2 位在AL 的低2 位
AND AL,03H;让AL 中仅保存移出的AX 高2 位数据
MOV BL ,AL;将AL 中的数据放入BL 中保存
POP AX;弹出原有的低十六位数据
POP DX;弹出原有的高十六位数据
SHL DX,CL;将高位数据算术逻辑左移2 位
SHL AX,CL;将低位数据算术逻辑左移2 位
OR DL,BL;将AX 中移出的高2 位数据放入DX 的低2 位
MOV [DI] ,AX
MOV [DI+2] ,DX
;右移2 位
LEA SI,FIRST
LEA DI,THIRD
MOV CX,2
CLC
MOV AX,[SI];AX=5F90H 为低十六位数据
INC SI
INC SI
MOV DX,[SI];DX=696EH 为高十六位数据
PUSH DX;保存原有的高十六位数据
PUSH AX;保存原有的低十六位数据
ROR AX,CL;将低位数据不带进位循环右移两位,即低2 位数据在AH 的高2 位
AND AH,0C0H;让AH 中仅保存移出的低2 位数据
PUSH CX
MOV CX,6
SHR AH,CL
POP CX
MOV [DI] ,AH;将移出的低2 位数据放入THIRD 中的最低单元中
ROR DX,CL;将低位数据不带进位循环左移两位,即AX 的高2 位在AL 的低2 位
AND DH,0C0H;让DH 中仅保存移出的DX 低2 位数据
MOV BL ,DH;将DH 中的数据放入BL 中保存
POP AX;弹出原有的低十六位数据
POP DX;弹出原有的高十六位数据
SHR DX,CL;将高位数据算术逻辑左移2 位
SHR AX,CL;将低位数据算术逻辑左移2 位
OR AH,BL;将DX 中移出的低2 位数据放入AX 的高2 位
MOV [DI+1] ,AX
MOV [DI+3] ,DX
MOV AH,4CH
INT 21H
CODE ENDS
END START
5.(14)在当前数据区从400H 开始的256 个单元中存放着一组数据,试编程序将它们顺序搬移到从A000H 开始的顺序256 个单元中。

解答:
DA TA SEGMENT
ORG 400H
DA T1 DB ...;256 DUP (?) ORG
0A000H
DA T2 DB ...;256 DUP (?)
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DATA
MOV DS,AX
;CH3-14
LEA SI,DAT1
LEA DI,DAT2
MOV CX,128
AGAIN: MOV AL,[SI]
MOV [DI],AL
INC SI
INC DI
LOOP AGAIN
;CH3-15,将两个数据块逐个单元进行比较,若有错BL=00H,否则BL=FFH
LEA SI,DAT1
LEA DI,DAT2
MOV CX,128
NEXT: MOV AL,[SI]
MOV BL,[DI]
CMP AL,BL
JNZ ERROR
INC SI
INC DI
LOOP NEXT
MOV BL,0FFH
JMP EXIT
ERROR: MOV BL,00H
EXIT: MOV AX,4C00H
INT 21H
CODE ENDS
END START
6.试编程序将当前数据区从BUFF 开始的4K 个单元中均写入55H,并逐个单元读出比较,看写入的与读出的是否一致。

若全对,则将ERR 单元置0H;如果有错,则将ERR 单元置FFH。

解答:
DA TA SEGMENT BUFF DB
1000H DUP(?)
ERR DB ?
DA TA ENDS
;
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START: MOV AX,DA TA
MOV DS,AX
;将55H 依次放入BUFF 开始的4K 个单元
LEA SI,BUFF
MOV CX,1000H
MOV AL,55H
NTXT: MOV [SI],AL
INC SI
LOOP NEXT
;取出与55H 比较,全对则ERR=0,否则ERR=FFH
LEA DI,BUFF
LEA SI,ERR
MOV CX,1000H
NEXT1: MOV AL,[DI]
INC DI
CMP AL,55H
JNZ ERROR;若有一个不同,即置ERR=FFH
LOOP NEXT1
MOV AL,00H
MOV [SI],AL;全比较完无错,则置ERR=0
JMP EXIT
ERROR: MOV
A L,0FFH MOV
[SI],AL ;返回DOS
EXIT: MOV AH,4CH
INT 21H
CODE ENDS
END START
END
7.在上题中,如果发现有错时,要求在ERR 单元中存放出错的数据个数,则程序该如何修改?解答:
DA TA SEGMENT BUFF DB
1000H DUP(?)
ERR DW ?
DA TA ENDS
;
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START: MOV AX,DA TA
MOV DS,AX
;将55H 依次放入BUFF 开始的4K 个单元
LEA SI,BUFF
MOV CX,1000H
MOV AL,55H
NTXT: MOV [SI],AL
INC SI
LOOP NEXT ;取
出与55H 比较LEA
D I,BUFF
LEA SI,ERR
MOV DX,0000H
MOV CX,1000H
NEXT1: MOV AL,[DI]
INC DI
CMP AL,55H
JZ NEXT2;若相同,则比较下一个
INC DX;否则将放出错个数的DX 加1
NEXT2:LOOP NEXT1 MOV
[SI],DX
;
EXIT: MOV AH,4CH
INT 21H
CODE ENDS
END START
END
8.试编写程序段,完成将数据区从0100H 开始的一串字节数据逐个从F0H 端口输出,已知数据串以0AH 为结束符。

解答:
DA TA SEGMENT
ORG 0100H
DA TA1 DB N DUP(?)
DA TA ENDS
;
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START: MOV AX,DA TA
MOV DS,AX
;将DATA1 数据串中的数据取出并从F0H 端口中输出
LEA SI,DATA1
MOV CX,N
MOV BL,0AH
NTXT: MOV AL,[SI]
CMP AL,BL
JZ EXIT
OUT 0F0H,AL
INC SI
LOOP NEXT
;返回DOS
EXIT: MOV AH,4CH
INT 21H
CODE ENDS
END START
END
9.(24)内存中以FIRST 和SECOND 开始的单元中分别存放着两个4 位用压缩BCD 码表示的十进制数, 低位在前。

编程序求这两个数的和,仍用压缩BCD 码表示, 并存到以THIRD 开始的单元。

解答:
DA TA SEGMENT
FIRST DW 3412H
SECOND DW 7856H
THIRD DB ?,?,?
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DATA
MOV DS,AX
LEA SI,FIRST
LEA DI,SECOND
LEA BX,THIRD
MOV CX,2
CLC
AGAIN: MOV AL,BYTE PTR[SI]
MOV DL,BYTE PTR[DI]
ADC AL,DL
DAA
MOV BYTE PTR[BX],AL
INC SI
INC DI
INC BX
LOOP AGAIN
JC AA
MOV BYTE PTR[BX],0
JMP EXIT
AA: MOV BYTE PTR[BX],1
EXIT: MOV AX,4C00H
INT 21H
CODE ENDS
END START
10.(27)设字变量单元A、B、C 存放有三个数,若三个数都不为零,则求三个数的和,存放在D 中;若有一个为零,则将其余两个也清零,试编写程序。

解答:
DA TA SEGMENT
A D
B ?
B DB ?
C DB ?
D DW ?
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DATA
MOV DS,AX
LEA SI,A
LEA DI,D
MOV AL,[SI]
CMP AL,00
JZ ZERO
ADC DX,AL
LEA SI,B
MOV AL,[SI]
CMP AL,00
JZ ZERO
ADC DX,AL
LEA SI,C
MOV AL,[SI]
CMP AL,00
JZ ZERO
ADC DX,AL
MOV [DI],DX
JMP EXIT
ZERO: MOV AL,0
MOV A,AL
MOV B,AL
MOV C,AL
;
EXIT: MOV AX,4C00H
INT 21H
CODE ENDS
END START
11.(16)试编程序,统计由TABLE 开始的128 个单元中所存放的字符“A”的个数,并将结果存放在DX 中。

解答:
DA TA SEGMENT
TABLE DB X1,X2, (X128)
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DATA
MOV DS,AX
LEA SI,TABLE
MOV DX,0
MOV CX,128
AGAIN: MOV AL,[SI]
CMP AL,'A'
JNZ NEXT
INC DX
NEXT: INC SI
LOOP AGAIN
MOV AX,4C00H
INT 21H
CODE ENDS
END START
12.试编制一个汇编语言程序,求出首地址为DA TA 的1000 个字数组中的最小偶数,并把它存放于MIN 单元中。

解答:
DA TA SEGMENT
ARRAY DW X1,X2, (X1000)
ARRAY_EVEN DW 1000 DUP(?)
MIN DW ?
MAX DW ?
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DA TA
MOV DS,AX
;将数组中的偶数放入ARRAY_EVEN 中
LEA SI,ARRAY
LEA DI,ARRAY_EVEN
MOV CX,1000
AGAIN: MOV AX,[SI]
TEST AX,01h
JNZ NEXT
MOV [DI],AX
INC DI
INC DI
NEXT: INC SI
INC SI
LOOP AGAIN
;找出ARRAY_EVEN 中的最大数
LEA SI,ARRAY_EVEN
MOV CX,999
MOV AX,[SI]
MOV BX,AX
INC SI
INC SI
NEXT: CMP AX,[SI]
JAE LL
MOV AX,[SI]
LL: INC SI
INC SI
LOOP NEXT
;找出ARRAY_EVEN 中的最小数(第13 题增加的部分)
LEA SI,ARRAY_EVEN
MOV CX,999
MOV AX,[SI]
MOV BX,AX
INC SI
INC SI
NEXT: CMP AX,[SI]
JBE SS
MOV AX,[SI]
SS: INC SI
INC SI
LOOP NEXT
MOV MIN,AX ;返回
DOS
MOV AX,4C00H
INT 21H
CODE ENDS
END START
13.在上题中,如果要求同时找出最大和最小的偶数,并把它们分别存放于MAX 和MIN 单元中,试完成程序。

解答:略(见第12 题)。

14.(28)在DATA 字数组中存放有100H 个16 位补码数,试编写一程序求它们的平均值,放在AX 中,并求出数组中有多少个数小于平均值,将结果存于BX 中。

解答:
DA TA SEGMENT
DA T DW X1,X2, (X256)
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DA TA
MOV DS,AX
;将数组中的100H 个数求和后求平均值
LEA SI,DAT
MOV CX,100H
CLC
MOV DX,0000
AGAIN: MOV AX,[SI]
ADD BX,AX
JNC NEXT
ADC DX,1
NEXT: INC SI
INC SI
LOOP AGAIN
MOV CX,100H
MOV AX,BX
DIV CX
;找出DAT 中的小于平均值的个数
LEA SI,DAT
MOV CX,100H
MOV DX,0000H
AGAIN0:MOV BX,[SI]
CMP BX,AX;与平均值AX 比较,大于等于则转NEXT0,否则将读数器DX 加1 JGE NEXT0
INC DX
NEXT0: INC SI
INC SI
LOOP AGAIN0
MOV BX,DX ;返回
DOS
MOV AX,4C00H
INT 21H
CODE ENDS
END START
15.(17)编写一个子程序,对AL 中的数据进行偶校验,并将经过校验的结果放回AL 中。

解答:
DA TA SEGMENT
COUNT EQU 7
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DATA
MOV DS,AX
PUSH AX
MOV DX,0
MOV CX,COUNT
AGAIN: RCR AL,1
JNC L
INC DX
L: LOOP AGAIN
POP AX
TEST DX,01
JZ EXIT
OR AL,80
EXIT: MOV AX,4C00H
INT 21H
;ANOTHER METHORD
JP EXIT
OR AL,80H
EXIT: MOV AX,4C00H
INT 21H
CODE ENDS
END START
16.(18)利用上题的予程序,对DATA 开始的256 个单元的数据加上偶校验,试编程序。

解答:
DA TA SEGMENT
DA T DB ...;256 DUP (?)
RESULT DB ...;256 DUP (?)
NUM EQU 256
COUNT EQU 7
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DATA
MOV DS,AX
LEA SI,DAT
LEA DI,RESULT
MOV CX,NUM
NEXT: MOV AL,[SI]
CALL SUB1
MOV [DI],AL;MOV [SI],AL
INC SI
INC DI
LOOP NEXT
MOV AX,4C00H
INT 21H
SUB1 PROC
PUSH AX
MOV DX,0
MOV CX,COUNT
AGAIN: RCR AL,1
JNC L
INC DX
L: LOOP AGAIN
POP AX
TEST DX,01
JZ QUIT
OR AL,80H
QUIT: RET
SUB1 ENDP
CODE ENDS
END START
17.(19)试编写程序实现将键盘输入的小写字母转换成大写字母并输出。

解答:
DA TA SEGMENT
MESS DB 'THE INPUT IS NOT CORRECT.',0DH,0AH,'$'
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DATA
MOV DS,AX
NEXT: MOV AH,01H
INT 21H
CMP AL,'Q'
JZ EXIT
CMP AL,'a'
JB ERROR
CMP AL,'z'
JA ERROR
SUB AL,20H
MOV AH,02H
MOV DL,AL
INT 21H
JMP NEXT
ERROR: MOV AH,09H
LEA DX,MESS
INT 21H
JMP NEXT
EXIT: MOV AX,4C00H
INT 21H
CODE ENDS
END START
18.从键盘接收20 个字符,按键入顺序查找最大的字符,并显示输出。

解答:
DA TA SEGMENT
DA T DB 20 DUP(?)
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DA TA
MOV DS,AX
;从键盘接收20 个字符,并送DAT 中保存
LEA SI,DAT
MOV CX,20
NEXT: MOV AH,01H
INT 21H
MOV [SI],AL
INC SI
LOOP NEXT
;比较20 个字符中的最大字符,并放入AL 中
MOV CX,19
LEA SI,DAT
MOV AL,[SI]
INC SI
NEXT1: CMP AL,[SI]
JAE LL
MOV AL,[SI]
LL: INC SI
LOOP NEXT1
;将最大的字符的ASCII 码由AL 送DL 显示
MOV DL,AL
MOV AH,2H
INT 21H
;返回DOS
MOV AX,4C00H
INT 21H
CODE ENDS
END START
19.(29)编写汇编程序,接收从键盘输入的10 个数,输入回车符表示结束,然后将这些数加密后存于BUFF 缓冲区中。

加密表为:
输入数字:0,1,2,3,4,5,6,7,8,9;密码数字:7,5,9,1,3,6,8,0,2,4解答:
DA TA SEGMENT
BUFF DB 10 DUP(?)
TABLE DB 7,5,9,1,3,6,8,0,2,4
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DATA MOV
DS,AX
;
LEA DI,BUFF
NEXT: MOV AH,01H
INT 21H;从键盘上接收单个字符
CMP AL,0AH;与0AH 比,判是否要结束
JZ EXIT
SUB AL,30H;否则,将0~9 的ASCII 码转换为十进制数
LEA BX,TABLE
XLAT;用查表指令进行加密
MOV [DI],AL
INC DI
JMP NEXT
;退出并返回DOS
EXIT: MOV AX,4C00H
INT 21H
CODE ENDS
END START
20.(23)有一个100 个字节的数据表,表内元素已按从大到小的顺序排列好,现给定一元素,试编程序在表内查找,若表内已有此元素,则结束;否则,按顺序将此元素插入表中适当的位置,并修改表长。

解答:
;调试时用了十个数据,本程序已通过调试
DA TA SEGMENT
TABLE_LEN DB ?
X DB 99H
TABLE DB 98H,90H,80H,70H,60H,50H,40H,30H,20H,10H;X1,X2,...,X100
COUNT EQU $-TABLE
DA TA ENDS
;
STACK SEGMENT
STACK ENDS
;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DA TA
START: MOV AX,DA TA
MOV DS,AX
;将数组中的100H 个数求和后求平均值
MOV DX,0000
LEA SI,TABLE
MOV CX,COUNT
MOV AL,X;假设X 为给定元素
;在TABLE 中是否有元素X
AGAIN: MOV BL,[SI]
CMP BL,AL
JZ EXIT
INC SI
LOOP AGAIN
;X 元素不在表中,将X 插入表中适当位置
LEA SI,TABLE
MOV DI,SI;DI 为表的末地址
ADD DI,COUNT-1
MOV CX,COUNT
AGAIN0:MOV BL,[SI]
CMP BL,AL
JA NEXT0
BB: CMP DI,SI
JZ AA
MOV AH,[DI]
MOV [DI+1],AH;将比X 小的元素后移一位
DEC DI
JMP BB
AA: MOV [DI+1],BL
MOV [DI],AL
MOV TABLE_LEN,COUNT+1
JMP EXIT
NEXT0: INC SI
LOOP AGAIN0
MOV [DI+1],AL;若比较后,X 元素为最小,则放在最末单元的后面,并将表长加1 MOV TABLE_LEN,COUNT+1
;退出并返回DOS
EXIT: MOV AX,4C00H
INT 21H
CODE ENDS
END START
21.(26)在当前数据段(DS),偏移地址为DA TAB 开始的顺序80 个单元中,存放着某班
80 个同学某门考试成绩。

按要求编写程序:
①编写程序统计≥90 分;80 分~89 分;70 分~79 分;60 分~69 分,<60 分的人数各为多少,并将结果放在同一数据段、偏移地址为BTRX 开始的顺序单元中。

②试编程序,求该班这门课的平均成绩为多少,并放在该数据段的A VER 单元中。

解答:
;统计学生成绩
DATA SEGMENT
DATAB DB X1,X2,...,X80
N EQU $-DATAB
ORG 100H
BTRX DW 0
S8 DW 0
S7 DW 0
S6 DW 0
S5 DW 0
ORG 110H
A VER DW ?
DATA ENDS

STACK SEGMENT STACK
STA DB 20 DUP (0)
TOP EQU $—STA
STACK ENDS

CODE SEGMENT
MAIN PROC FAR
ASSUME CS:CODE,DS:DATA,SS:STACK START:PUSH DS
SUB AX,AX PUSH
AX MOV AX,DATA
MOV DS,AX
MOV CX,N
MOV BX,0000H
MOV DX,0000H
LEA SI,DATAB;成绩表首地址COMPARE:MOV AL,[SI]
CMP AL,60 JL
;<60?
FIVE
CMP AX,70
;<70?
JL SIX
CMP AX,80 JL
;<80?
SEVEN
CMP AX,90
;<90?
JL EIGHT
INC S9
JMP CHA
EIGHT:INC S8 JMP CHA
SEVEN:INC S7 JMP CHA
SIX:INC S6 JMP CHA
FIVE:INC S5 JMP CHA
CHA:
ADD BX,AL
JNC NEXT
ADC DX,0
NEXT:INC SI;循环学生人数LOOP COMPARE
MOV AX,BX
MOV CX,N
DIV CX
MOV A VER,AX
MOV AH,4CH
INT 21H
RET
MAIN ENDP
CODE ENDS
END START
CH04 存储系统
习题与思考题
1.存储器的哪一部分用来存储程序指令及像常数和查找表一类的固定不变的信息?哪一部
分用来存储经常改变的数据?解答:只读存储器ROM;随机存储器RAM。

2.术语“非易失性存储器”是什么意思?PROM 和EPROM 分别代表什么意思?
解答:“非易失性存储器”是指当停电后信息会丢失;PROM--可编程序的只读存储器PROM(Programmable ROM),EPROM--可擦除的可编程的只读存储器EPROM(Erasible Programmable ROM)。

3.微型计算机中常用的存储器有哪些?它们各有何特点?分别适用于哪些场合?解答:
双极型半导体存储器随机存储器
(RAM)
MOS存储器(静态、动态)主存储器可编
程只读存储器PROM
可擦除可编程只读存储器EPROM,EEPROM
只读存储器(ROM)掩膜型只读存储器MROM 快
擦型存储器存储器磁盘(软盘、硬盘、盘组)存储
器辅助存储器磁带存储器光盘存储器缓冲存储器
4.现代计算机中的存储器系统采用了哪三级分级结构,主要用于解决存储器中存在的哪些问题?解答:目前在计算机系统中通常采用三级存储器结构,即使用高速缓冲存储器、主存储器和辅助存储器,由这三者构成一个统一的存储系统。

从整体看,其速度接近高速缓存的速度,其容量接近辅存的容量,而位成本则接近廉价慢速的辅存平均价格。

三级结构主要用于解决速度、容量和成本的问题。

5.试比较静态RAM 和动态RAM 的优缺点,并说明有何种方法可解决掉电时动态RAM 中信息的保护。

解答:静态RAM----存储一位信息的单元电路可以用双极型器件构成,也可用MOS 器件构成。

双极型器件构成的电路存取速度快,但工艺复杂,集成度低,功耗大,一般较少使用这种电路,而采用MOS 器件构成的电路。

静态RAM 的单元电路通常是由6 个
MOS 管子组成的双稳态触发器电路,可以用来存储信息“0”或者“1”,只要不掉电,“0” 或“1”状态能一直保持,除非重新通过写操作写入新的数据。

同样对存储器单元信息的读出过程也是非破坏性的,读出操作后,所保存的信息不变。

使用静态RAM 的优点是访问速度快,访问周期达20~40ns。

静态RAM 工作稳定,不需要进行刷新,外部电路简单,但基本存储单元所包含的管子数目较多,且功耗也较大,它适合在小容量存储器中使用。

动态RAM----与静态RAM 一样,由许多基本存储单元按行和列排列组成矩阵。

最简单的动态RAM 的基本存储单元是一个晶体管和一个电容,因而集成度高,成本低,耗电少,但它是利用电容存储电荷来保存信息的,电容通过MOS 管的栅极和源极会缓慢放电而丢失信息,必须定时对电容充电,也称刷新。

另外,为了提高集成度,减少引脚的封装数,DRAM 的地址线分成行地址和列地址两部分,因此,在对存储器进行访问。

相关文档
最新文档