微型计算机原理习题参考答案
CH01微型计算机概述
习题与思考题
1.微型计算机由哪些部件组成?各部件的主要功能是什么?解答:
算术逻辑部件(ALU)微处理器累加器、寄存器
(CPU)
控制器系统总线:AB、CB、DB
(功能:为CPU和其他部件之间提供数据、地址微型计算机 和控制信息的传输通道)
微机系统输入/输出(I/O)接口:串/并行接口等
(功能:使外部设备和微型机相连)
存储器:只读存储器(ROM)、随机存储器(RAM)
(功能:用来存储信息)
操作系统(OS)系统软件
系统实用程序:汇编、编译、编辑、调试程序等外围设备:打印
机、键盘、CRT、磁盘控制器等
(注:CPU的功能--①可以进行算术和逻辑运算; ②可保存少量数据;
③能对指令进行译码并执行规定的动作; ④能和存储器、外设交换数据;
⑤提供整修系统所需要的定时和控制; ⑥可以响应其他部件发来的中断请示。)
2. 8086/8088 CPU 由哪两部分组成?它们的主要功能各是什么?是如何协调工作的?解答:
总线接口部件(BIU):负责与存储器、I/O端口传送数据
微处理(CPU)
器
执行部件(EU):负责指令的执行
- 1 -
微型计算机原理习题参考答案
协调工作过程:总线接口部件和执行部件并不是同步工作的,它们按以下流水线技术原则来
协调管理: ① 每当 8086 的指令队列中有两个空字节,或者 8088 的指令队列中有一个空字节时,总线接口部件就会自动把指令取到指令队列中。
② 每当执行部件准备执行一条指令时,它会从总线接口部件的指令队列前部取出指令的代码,然后用几个时钟周期去执行指令。在执行指令的过程中,如果必须访问存储器或者输入/输出设备,那么,执行部件就会请求总线接口部件进入总线周期,完成访问内存或者输入/输出端口的操作;如果此时总线接口部件正好处于空闲状态,那么,会立即响应执行部件的总线请求。但有时会遇到这样的情况,执行部件请求总线接口部件访问总线时,总线接口部件正在将某个指令字节取到指令队列中,此时总线接口部件将首先完成这个取指令的操作,然后再去响应执行部件发出的访问总线的请求。
③ 当指令队列已满,而且执行部件又没有总线访问请求时,总线接口部件便进入空闲状态。
④ 在执行转移指令、调用指令和返回指令时,由于程序执行的顺序发生了改变,不再是顺序执行下面一条指令,这时,指令队列中已经按顺序装入的字节就没用了。遇到这种情况,指令队列中的原有内容将被自动消除,总线接口部件会按转移位置往指令队列装入另一个程序段中的指令。
3. 8086/8088 CPU 中有哪些寄存器?各有什么用途?标志寄存器 F 有哪些标志位?各在什么情况下置位?解答:
寄存器 数 据寄存器 AX BX CX DX 变 址寄存器 指 针寄存器 控 制寄存器 段寄存器 SI DI SP BP IP PSW CS DS SS ES PF、CF。
标志寄存器 F 的各标志位置位情况:
· CF:进位标志位。做加法时出现进位或做减法时出现借位,该标志位置 1;否则清 0。 ·PF:奇偶标志位。当结果的低 8 位中 l 的个数为偶数时,该标志位置 1;否则清 0。
字乘法,字除法,字 I/O 查表转换 串操作,循环次数 功 能 字节相乘,字节相除,间接 I/O 源变址寄存器,用于指令的变址寻址 目的变址寄存器,用于指令的变址寻址 堆栈指针寄存器,与 SS 一起来确定堆栈在内存中的位置 基数指针寄存器,用于存放基地址,以使 8086/8088 寻址更加灵活 控制 CPU 的指令执行顺序 用来存放 8086/8088CPU 在工作过程中的状态 控制程序区 控制数据区 控制堆栈区 控制数据区 标志寄存器 F 的标志位:①控制标志:OF、DF、IF、TF;②状态标志:SF、ZF、AF、
- 2 -
微型计算机原理习题参考答案
·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
6 BH 5AH - 3 - · · · · · · 3 4 H 1 2 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
/S(BHE07) 、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 完成不同的动作。
- 4 -
微型计算机原理习题参考答案
10. 8086/8088 CPU 有哪些基本操作?基本的读/写总线周期各包含多少个时钟周期?什么情况下需要插入 Tw 周期?应插入多少个 Tw 取决于什么因素?解答:①8086/8088CPU 最小模式下的典型时序有:存储器读写;输入输出;中断响应;系统复位及总线占用操作。 ②一个基本的 CPU 总线周期一般包含四个状态T1、T2、T3、T4 ,即四个时钟周期; ③在存储器和外设速度较慢时,要在T3之后插入 1 个或几个等待状态Tw;
④应插入多少个 Tw 取决于 READY 信号的状态,CPU 没有在 T3 状态的一开始采样到 READY 信号为低电平,就会在T3和T4之间插入等待状态Tw,直到采样到 READY 信号为高电平。
11.试说明 8086/8088 工作在最大和最小模式下系统基本配置的差异。8086/8088 微机系统中为什么一定要有地址锁存器?需要锁存哪些信息?解答:最大模式配置和最小模式配置有一个主要的差别:①就是在最大模式下,需要用外加电路来对 CPU 发出的控制信号进行变换和组合,以得到对存储器和 I/O 端口的读/写信号及对锁存器(8282)和对总线收发器(8286)等等的控制信号。8288 总线控制器就是完成上面这些功能的专用芯片。②为多中断源的需要,常采用中断优先权控制电路(如 Intel8259A)。
8086/8088 系统一定要有地址锁存器――因为高四位地址和状态信号是从同一组引脚上分时送出的,低 16 位地址和数据是从同一组引脚上分时传输的,所以必须把地址信息锁存起来。
需要锁存的信息:地址信号、BHE/S7 和IO/M(8086 为M/IO)信号进行锁存。
12.试简述 8086/8088 微机系统最小模式下从存器储读数据时的时序过程。
解答:正常的存储器读总线操作占用 4 个时钟周期,通常将它们称为 4 个 T 状态即 T1~
T4。
1 T1 状态,IO/ M =0,指出要访问存储器。送地址信号 A19-0,地址锁存信号 ALE 有效,用来控制 8282 锁存地址。DT/ R =0,控制 8286/8287 工作在接收2 状态(读)。 T2 状态,A19~A16 送状态 S6 ~S3,AD7 ~AD0 浮空,准备接收数据。同时,RD
=0,表示要进行读操作,而DEN =0 作为 8286/8287 的选通信号,允许进行数据传输。
3 T3 状态,从指定的存储单元将数据读出送 AD7 ~AD0。若存储器速度较慢,不能及时读出数据的话,则通过 READY 引脚通知 CPU,CPU 在 T3 的前沿采样 READY,如果 READY=0,则在 T3 结束后自动插入 1 个或几个等待状态 TW并在每个 TW 的前沿检
,
测 READY,等到 READY 变高后,就自动脱离 TW 进入 T4。
4T4 状态,CPU 采样数据线,获得数据。RD 、DEN 等信号失效。
- 5 -
微型计算机原理习题参考答案
CH02 8086/8088指令系统
习题与思考题
1.假定 DS=2000H,ES=2100H,SS=1500H,SI=00A0H,BX=0100H,BP=0010H,数据变量 VAL 的偏移地址为 0050H,请指出下列指令源操作数是什么寻址方式?源操作数在哪里?如在存储器中请写出其物理地址是多少? (1)MOV AX,0ABH (2)MOV AX,[100H] (3)MOV AX,VAL (4)MOV BX,[SI] (5)MOV AL,VAL[BX] (6)MOV CL,[BX][SI]
(7)MOV VAL[SI],BX (8)MOV 解答: [BP][SI],100
(1)MOV
AX,0ABH 寻址方式:立即寻址;
物理地址:无 (2)MOV
AX,[100H]
寻址方式:直接寻址;源操作数在存储器中;物理地址: DS* 16+100H=
2000H*16+100H=20100H
(3)MOV AX,VAL 寻址方式:直接寻址;源操作数在存储器中;物理地址: DS *
16+VAL = 2000H*16+0050H=20050H
(4)MOV BX,[SI] 寻址方式:寄存器间接寻址;源操作数在存储器中;物理地址:
DS*16+SI= 2000H*16+00A0H=200A0H
(5)MOV AL,VAL[BX] 寻址方式:变址寻址;源操作数在存储器中;物理地址:
DS*16+VAL+BX=
2000H*16+0050H+0100
=20150H
(6)MOV CL,[BX][SI] 寻址方式:基址加变址寻址;源操作数在存储器中;物理
地址:DS*16+BX+SI=
2000H*16+0100H+00A0H
=201A0H
(7)MOV
VAL[SI],BX
寻址方式:寄存器寻址;源操作数在寄存器中;物理地址:无 (8)MOV
[BP][SI],100
寻址方式:立即寻址;物理地址:无
2.设有关寄存器及存储单元的内容如下:
- 6 -
微型计算机原理习题参考答案
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] 行 结 果 (5)MOV [BX][SI],AL (6)MOV AX,1100[BX][SI] 解答: 执 AX=1800H AX=0100H BX=4C2AH DX=4C2AH [20102H]=00H AX=65B7H (1) MOV AX,1800H (2) MOV AX,BX (3) MOV BX,[1200H] (4) MOV DX,1100[BX] (5) MOV [BX][SI],AL (6) MOV AX,1100[BX][SI] 3.假定 BX=0E3H,变量 VALUE=79H,确定下列指令执行后的结果(操作数均为无符号数。
对 3、6,写出相应标志位的状态)。 (1)ADD (3)CMP (5)DEC
解答: 题号 VALUE,BX BX,VALUE BX 指 令 (2)AND BX,
VALUE
(4)XOR BX,0FFH (6)TEST BX,01H
执 行 结 果 (1) ADD (2) AND (3) CMP (4) XOR (5) DEC VALUE,BX BX,VALUE BX,VALUE BX,0FFH BX BX=015CH BX=0061H BX=00E3H(CF=ZF=OF=SF=0,AF=PF=1) BX=001CH BX=00E2H BX=00E3H(CF=ZF=OF=SF=AF=PF=0) (6) TEST BX,01H 4.已知 SS=0FFA0H,SP=00B0H,先执行两条把 8057H 和 0F79H 分别进栈的 PUSH 指令,再执行一条 POP 指令,试画出堆栈区和 SP 内容变化的过程示意图。(标出存储单元的地址)解答:
堆栈段SS=0FFA0H 堆栈段SS=0FFA0H
- 7 -
微型计算机原理习题参考答案 X · · · 00ADHFFAADH
00AEHFFAAEH
00AFHFFAAFH 0FFA0:00B0HFFAB0H
·· ·· ··
79H 0FH 57H 80H X · · · ①初始状态;SP=00B0H
堆栈段SS=0FFA0H 57H 80H X · · · FFAABHFFAABH 00ACHFFAACH 00ACHFFAACH 00ADHFFAADH00AEHFFAAEH
00AFHFFAAFH
0FFA0:00B0HFFAB0H
②PUSH AX;(AX=8057H)SP=00AEH堆栈段SS=0FFA0H
- 8 -
微型计算机原理习题参考答案 FFAABHFFAABH 00ACHFFAACH 00ACHFFAACH 00ADHFFAADH 00AEHFFAAEH 00AFHFFAAFH ·· ·· ·· 00ADHFFAADH 00AEHFFAAEH 00AFHFFAAFH 0FFA0:00B0HFFAB0H 57H 80H X · · · 0FFA0:00B0HFFAB0H ③PUSH BX;(BX=0F79H)SP=00ACH ④POP BX;SP=00AEH 5.已知程序段如下:
MOV MOV ROL DEC
AX,1234H CL,4 AX,CL AX
MOV CX,4 MUL CX 试问:(1)每条指令执行后,AX 寄存器的内容是什么?(2)每条指令执行后,CF,SF 及
ZF 的值分别是什么?(3)程序运行结束时,AX 及 DX 寄存器的值为多少? 指 令 执 行 AX 结 果 CF × × 1 1 1 0 SF × × 0 0 0 0 ZF × × 0 0 0 0 MOV AX,1234H MOV CL,4 ROL DEC AX,CL AX AX=1234H AX=1234H AX=2341H AX=2340H AX=2340H MOV CX,4 MUL CX AX=8D00H,DX=0000H 6.写出实现下列计算的指令序列。(假定 X、Y、Z、W、R 都为字变量) (1)Z=W+(Z+X) 题号 (2)Z=W-(X+6)-(R+9)
令 题号 (2) (3)Z=(W*X)/(R+6) (4)Z=((W-X)/5*Y)*2 解答:(1)Z=W+(Z+X) 指 指 令 (1) Z=W+(Z+X) Z=W-(X+6)-(R+9) MOV ADD DX,R DX,9 MOV MOV AX,Z BX,X - 9 -
微型计算机原理习题参考答案
MOV ADD ADC MOV CX,W BX CX Z,AX (4) MOV ADD MOV SUB SUB MOV BX,X BX,6 AX,W AX,BX AX,DX Z,AX (3) Z=(W*X)/(R+6) Z=((W-X)/5*Y)*2 MOV MOV SUB MOV MOV DIV MOV MUL MOV MUL MOV MOV AX,W BX,X AX,BX DX,0 CL,5 CL BX,Y BX CL,2 CL Z,AX Z+1,DX MOV MOV MOV MUL PUSH MOV ADD MOV POP DIV MOV MOV DX,0 AX,W BX,X BX AX AX,R AX,6 CX,AX AX CX Z,AX Z+1,DX 7.假定 DX=1100100110111001B,CL=3,CF=1,试确定下列各条指令单独执行后 DX 的值。
(1)SHR DX,1 DH,1 DX,CL DL,1 指 DX,1 DL,1 令 (2)SHL (4)SAR (6)ROL (8)RCL
DL,1 DX,CL DL,CL DX,CL 执 行 结 果 (3)SAL (5)ROR (7)RCR 解答: 题号 (1) SHR (2) SHL DX=0110 0100 1101 1100(64DCH) DX=1100 1001 0111 0010(C972H) - 10 -
微型计算机原理习题参考答案
(3) SAL (4) SAR (5) ROR (6) ROL (7) RCR (8) RCL DH,1 DX,CL DX,CL DL,CL DL,1 DX,CL DX=1001 0010 1011 1001(92B9H) DX=1111 1001 0011 0111(F937H) DX=0011 1001 0011 0111(3937H) DX=1100 1001 1100 1101(C9CDH) DX=1100 1001 1101 1100(C9DCH) DX=0100 1101 1100 1011(4DCFH) 8.已知 DX=1234H,AX=5678H,试分析下列程序执行后 DX、AX 的值各是什么?该程序完成了什么功能?
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 1 2 3 4 DX 2 3 4 0
AX 5 6 7 8 AX
6 7 8 0 2 3 4 5 6 7 8 0 DX AX
9.试分析下列程序段:
ADD JNC SUB JNC JMP
AX,BX L2 AX,BX L3 SHORTL5
BX
如果 AX、BX 的内容给定如下: AX
(1)14C6H 80DCH
(2)B568H 54B7H
问该程序在上述情况下执行后,程序转向何处?
解答:(1)AX=AX+BX=14C6H+80DCH=95A2H;CF=0;无进位,转移至 L2;
(2)方法同(1),略
- 11 -
微型计算机原理习题参考答案
10.编写一段程序,比较两个 5 字节的字符串 OLDS 和 NEWS,如果 OLDS 字符串不同于
NEWS 字符串,则执行 NEW_LESS,否则顺序执行。
解答:编程如下,(说明:左测程序为常规编法,两个字符串在一个数据段中;右测的程序
要求 OLDS 在数据段中,NEWS 在附加段中,利用串操作的指令是可行的)
LEA SI,OLDS; LEA DI,NEWS; MOV CX,5;
NEXT: MOV AL,[SI];
MOV BL,[DI]; CMP AL,BL; JNZ NEW_LESS; INC SI; INC DI; LOOP NEXT; ??
JMP EXIT
NEW_LESS:
??
EXIT: ??
EXIT:
LEA SI,OLDS LEA DI,NEWS MOV CX,5 CLD
REPE CMPSB JNZ NEW_LESS ?? JMP EXIT
NEW_LESS:
?? ??
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 ASC3
DW 694,12
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
- 12 -
微型计算机原理习题参考答案
INC SI INC DI INC DI INC BX INC BX LOOP NEXT
CH03 汇编语言程序设计
习题与思考题
1.下列语句在存储器中分别为变量分配多少字节空间?并画出存储空间的分配图。 VAR1 VAR2 VAR3 VAR4
DB DW DD
10,2
5 DUP(?),0 -1,1,0
DB ‘HOW ARE YOU?’,3 DUP(1,2)
解答:字节空间----VAR1:2;VAR2:12;VAR3:20;VAR4:12。 存储空间的分配图:
DS:0000
0010
0020
0A 02 00 00 00 00 00 00—00 00 00 00 00 00 48 57 20 20 41 52 45 20 20—59 4F 55 3F 01 02 01 01 02 FF FF FF FF 01 00—00 00 00 00 00 00
4F 02
2.假定 VAR1 和 VAR2 为字变量,LAB 为标号,试指出下列指令的错误之处。 (1)ADD (3)JMP (5) MOV 寄存器;
VAR1,VAR2 LAB[CX]
[1000H],100 (6)SHL
(2)SUB (4)JNZ
AL,VAR1 VAR1
AL, 4 解答:(1)两个操作数中至少有一个为
(2)AL 为字节,VAR1 为字变量,不匹配; (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
EQU 2048 (3)CMP A1,A2 (4)K1
解答:(1)K1 为常量,不能用 MOV 指令赋值;
(2)A1 为字节,AX 为字变量,不匹配; (3)A1 未定义,无法做比较指令; (4)K1 重新赋值前,必须用 PURGE 释放。
- 13 -
微型计算机原理习题参考答案
4.数据定义语句如下所示:
FIRST DB SECOND DB 90H,5FH,6EH,69H 5 DUP(?)
THIRD DB 5 DUP(?) 自 FIRST 单元开始存放的是一个四字节的十
六进制数(低位字节在前),要求:
编一段程序将这个数左移两位后存放到自 SECOND 开始的单元,右移两位后存放到自 THIRD 开始的单元。(注意保留移出部分) 解答: DATA
SEGMENT
FIRST DB 90H,5FH,6EH,69H SECOND DB 5 DUP(?) THIRD DB 5 DUP(?) ENDS
SEGMENT
DATA CODE
ASSUME CS:CODE,DS:DATA START:MOV AX,DATA
MOV DS,AX LEA SI,FIRST LEA DI,SECOND MOV CX,2 CLC
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 位数据
;左移 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 POP
AX;弹出原有的低十六位数据 DX;弹出原有的高十六位数据
SHL DX,CL;将高位数据算术逻辑左移 2 位 SHL AX,CL;将低位数据算术逻辑左移 2 位
OR DL,BL;将 AX 中移出的高 2 位数据放入 DX 的低 2 位
MOV [DI] ,AX MOV [DI+2] ,DX ;右移 2 位
- 14 -
微型计算机原理习题参考答案
CODE END
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 SHR POP
CX,6 AH,CL 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 POP
AX;弹出原有的低十六位数据 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 ENDS START
5.(14)在当前数据区从 400H 开始的 256 个单元中存放着一组数据,试编程序将它们顺序搬移到从 A000H 开始的顺序 256 个单元中。 解答:
DATA SEGMENT
ORG 400H
DAT1 DB ...;256 DUP (?) ORG
0A000H
DAT2 DB ...;256 DUP (?) DATA ENDS ;
- 15 -
微型计算机原理习题参考答案
STACK SEGMENT STACK ENDS ;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATA 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。解答:
DATA SEGMENT BUFF DB 1000H DUP(?)
- 16 -
微型计算机原理习题参考答案
ERR DATA ;
CODE
DB ? ENDS SEGMENT
CS:CODE,DS:DATA
ASSUME
START: MOV AX,DATA
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 AL,0FFH MOV [SI],AL ;返回 DOS
EXIT: MOV AH,4CH INT 21H CODE ENDS END START END
7.在上题中,如果发现有错时,要求在 ERR 单元中存放出错的数据个数,则程序该如何修改?解答:
DATA SEGMENT BUFF DB 1000H DUP(?) ERR DATA ; CODE
DW ? ENDS SEGMENT
CS:CODE,DS:DATA
ASSUME
START: MOV AX,DATA
- 17 -
微型计算机原理习题参考答案
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 DI,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 为结束符。解答: DATA SEGMENT ORG 0100H
DATA1 DB N DUP(?) DATA ; CODE
ENDS SEGMENT
ASSUME CS:CODE,DS:DATA START: MOV AX,DATA MOV DS,AX
;将 DATA1 数据串中的数据取出并从 F0H 端口中输出 LEA SI,DATA1 MOV CX,N MOV BL,0AH NTXT: MOV AL,[SI]
- 18 -
微型计算机原理习题参考答案
CMP JZ OUT INC
AL,BL EXIT 0F0H,AL SI
LOOP NEXT
;返回 DOS
EXIT: MOV AH,4CH INT CODE END END
9.(24)内存中以 FIRST 和 SECOND 开始的单元中分别存放着两个 4 位用压缩 BCD 码表示的十进制数, 低位在前。编程序求这两个数的和,仍用压缩 BCD 码表示, 并存到以 THIRD 开始的单元。解答: DATA SEGMENT FIRST DW 3412H SECOND DW 7856H THIRD DB ?,?,? DATA ENDS ;
STACK SEGMENT STACK ENDS ;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATA 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
- 19 -
21H ENDS START
微型计算机原理习题参考答案
JC AA
MOV BYTE PTR[BX],0
AA:
JMP EXIT
MOV BYTE PTR[BX],1
EXIT: MOV AX,4C00H
INT 21H CODE ENDS END START
10.(27)设字变量单元 A、B、C 存放有三个数,若三个数都不为零,则求三个数的和,存放在 D 中;若有一个为零,则将其余两个也清零,试编写程序。 解答:
DATA SEGMENT A DB ? B DB ? C DB ? D DW ? DATA ENDS ;
STACK SEGMENT STACK ENDS ;
CODE SEGMENT
ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATA START: MOV AX,DATA
MOV DS,AX LEA LEA MOV CMP JZ ADC LEA
SI,A DI,D AL,[SI] AL,00 ZERO DX,AL SI,B
MOV AL,[SI] CMP AL,00 JZ ZERO ADC LEA
DX,AL SI,C
MOV AL,[SI] CMP AL,00 JZ ZERO
- 20 -
微型计算机原理习题参考答案
MOV AL,48H OUT 21H,AL
; 送 ICW2,即中断类型码的高 5 位
;送 ICW4,所有×的位全取 0
MOV AL,000× ××01B(01H) OUT 21H,AL
MOV AL,1110 0000B(E0H);送 OCW1 OUT 21H,AL
14.某系统中设置两片 8259A 级联使用,从片接至主片的 IR2,同时,两片芯片的 IR3 上还分别连接了一个中断源,要求电平触发,普通 EOI 结束。编写全部的初始化程序。(端口地址可用自定)解答:
;8259 的初始化(主片)
MOV AL,×××1 1×01B(19H) OUT 20H,AL MOV AL,0000 0100B OUT 21H,AL
MOV AL,0001 ××01B OUT 21H,AL
MOV AL,1111 0011B(F3H);送 OCW1 OUT 21H,AL
;8259 的初始化(从片略)
; 送 ICW3
;送 ICW1,所有×的位全取 0
;送 ICW4,所有×的位全取 0
15.设 8253 的通道 2 工作在计数方式,外部事件从 CLK2 引入,通道 2 计满 500 个脉冲向 CPU 发出中断请求,CPU 响应这一中断后重新写入计数值,开始计数,以后保持每 2 秒钟向 CPU 发出一个中断请求。假设条件如下:
①外部计数事件频率为 1kHz; ②中断类型码为 54H;
试完成硬件连接图并编写完成该任务的全部程序(包括芯片的初始化,中断向量的设置,中断服务子程序)。 解答:(略) 16.DMA 控制器 8237A 的主要功能是什么?其单字节传输方式与数据块传输方式有什么不同?
解答:(略)
17.某 8086 系统中使用 8237A 完成从存储器到存储器的数据传送,已知源数据块首地址的偏移地址值为 1000H,目标数据块首地址的偏移地址值为 2050H,数据块长度为 1K 字节,地址增量修改。试编写初始化程序。(端口地址分别为 00H~0FH)解答:(略) 18.某系统中使用 8237A 通道 0 完成从存储器到外设端口的数据传送任务(数据块传输方式),若已知芯片的端口地址分别为 EEE0H~EEEFH,要求通过通道 0 将存储器中偏移地址为 1000H~10FFH 的内容传送到显示器输出,DREQ、DACK 均为低有效,固定优先级。试编写初始化程序。 解答:(略)
- 46 -
百度搜索“70edu”或“70教育网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,70教育网,提供经典综合文库微型计算机原理及应用答案汇总在线全文阅读。
相关推荐: