第1章 习题和解答
15. 将下列十进制数分别转化为二进制数、十六进制数和BCD码。 (1)15.32=(0000 1111.0101 0001)2=(0F.51)16=(0001 0101.0011 0010)BCD
(2)325.16=(0001 0100 0101.0010 1000)2=(145.28)16=(0011 0010 0101.0001 0110)BCD (3)68.31=(0100 0100.0100 1111)2=(44.4F)16=(0110 1000.0011 0001)BCD
(4)214.126=(1101 0110.0010 0000)2=(0D6.20)16=(0010 0001 0100.0001 0010 0110)BCD 16. 将下列二进制数分别转化为十进制数和十六进制数。 (1)10110101= 181=0B5H (2)11001011= 203=0CBH (3)10101.1001= 21.5625=15.9 H (4) 101101.0101= 45.3125=2D.5H
17. 将下列十六进制数分别转化为二进制数、十进制数。 (1)FAH=1111 1010B=250
(2)12B8H=0001 0010 1011 1000B=4792
(3)5A8.62H=0101 1010 1000.0110 0010B=1448.3828125 (4)2DF.2H=0010 1101 1111.0010B=735.125
18. 若X=-107,Y=+74按8位二进制可写出:。[X]补=95H ,[Y]补=4AH , [X +Y]补=0DFH,[X-Y]补=4BH。
19. X=34AH,Y=8CH。问:有三位和两位十六进制数X和Y, (1)若X,Y是纯数(无符号数),则:X+Y=3D6H;X-Y=2BEH。
(2)若X,Y是有符号数,则:X+Y=2D6 H;X-Y=3BEH。 20. 已知X=85,Y=76(均为十进制数),求[-85]补,[-76]补。并利用补码的加、减法运算规则计算[X-Y]补,[-X+Y]补,[-X-Y]补。结果的各机器数及其真值请用十六进制表示,并由运算过程中的标志位OF判断结果是否溢出。
答:[X]补=[85]补=55H,[Y]补=[76]补=4CH , [-X]补=[-85]补=0ABH, [-Y]补=[-76]补=0B4H
[X-Y]补=[X]补+[-Y]补=55H+B4H=09H, OF=0 [-X+Y]补=[-X]补+[Y]补=ABH+4CH=0F7H, OF=0 [-X-Y]补=[-X]补+[-Y]补=ABH+B4H=5FH, OF=1 21. (1) 设[X]补=则[1/2X]补=1/2[X]补
(2) 设[X]补=则[-1/4X]补=[1/4[X]补]补补=00001011B
第2章 习题和解答
1. 8086是多少位的微处理器?为什么?
答:8086是高性能的第三代微处理器,是Intel系列的16位微处理器。
2. EU与BIU各自的功能是什么?如何协同工作?
答:EU其主要功能是执行命令。BIU其主要功能是负责完成CPU与存储器或I/O设备之间的数据传送。
总线接口部件BIU和执行部件EU并不是同步工作的, 两者的动作管理遵循如下原则: 每当8086的指令队列中有2个空字节,BIU就会自动把指令取到指令队列中。 而同时EU从指令队列取出一条指令,并用几个时钟周期去分析、执行指令。 当指令队列已满,而且EU对BIU又无总线访问请求时,BIU便进入空闲状态。
3. 8086/8088微处理器内部有那些寄存器,它们的主要作用是什么?
答:8086CPU内有14个16位的寄存器。其中有4个16位通用寄存器AX、BX、CX、DX,2个16位指针寄存器SP、BP,2个16位变址寄存器SI、DI,4个16位段寄存器CS、DS、SS、ES,1个16位指令指针寄存器IP及1个16位标志寄存器FLAGS。
寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令、数据和位址。 4. 8086对存储器的管理为什么采用分段的办法?
答:8086 CPU有20位地址总线,它可寻址的存储空间为1MB。而8086指令给出的地址编码只有16位,指令指针和变址寄存器也都是16位的,所以CPU不能直接寻址1 MB空间,为此采用分段管理。
5. 在8086中,逻辑地址、偏移地址、物理地址分别指的是什么?具体说明。 答:逻辑地址=物理地址:偏移地址;
偏移地址=相对于段起始地址的距离; 物理地址=段地址*10H+偏移地址
6. 给定一个存放数据的内存单元的偏移地址是20C0H,(DS)=0C00EH,求出该内存单元的物理地址。
答: 物理地址=段地址*10H+偏移地址=0C00E0H+20C0H=0C21A0H
7. 8086/8088为什么采用地址/数据引线复用技术? 答:8086/8088 CPU具有40条引脚,采用分时复用地址数据总线,从而使8086/8088 CPU用40条引脚实现20位地址、16位数据、控制信号及状态信号的传输。 8. 8086与8088的主要区别是什么?
答:8086有16位数据线,8088有8位数据线。 9. 怎样确定8086的最大或最小工作模式? 答:8088/8086CPU的
引脚固定接+5V时,CPU处于最小模式下,
引脚固
定接地时,CPU处于最大模式下。
10. 8086被复位以后,有关寄存器的状态是什么?微处理器从何处开始执行程序?
答:复位信号输入之后,CPU结束当前操作,并对处理器的标志寄存器、IP、DS、SS、ES寄存器及指令队列进行清零操作,而将CS设置为0FFFFH。
11. 8086基本总线周期是如何组成的?各状态中完成什么基本操作?
答:一个基本的总线周期由4个T状态组成,我们分别称为T1-T44个状态,在每个T状态下,CPU完成不同的动作。
T1状态:根据IO/M确定对存贮器或I/O操作,20位地址A0~A19信号有效,地址锁存信号ALE有效,给出DT/R信号控制8286数据传输方向。
T2状态:高四位地址/状态线送出状态信息S3~S6,低16位地址/数据线浮空,为下面传送数据准备;WR或RD有效,表示要对存贮器/I/O端口进行读或写;线收发器(驱动器)可以传输数据。
有效,使得总
T3状态:从存贮器或者I/O端口读出的数据送上数据总线(通过)。
Tw状态:若存贮器或外设速度较慢,不能及时送上数据的话,则通过READY线通知CPU,CPU在
的前沿(即
结束末的下降沿)检测READY,若发现READY=0,则在,并在每个
结束
后自动插入1个或几个脱离
进入
。 与
(或
的前沿处检测READY,等到READY变高后,则自动
T4状态:在)的交界处(下降沿),采集数据,使各控制及状态线进入无效。
13. 8086中断分哪两类?8086可处理多少种中断?
答:中断共分为两类:硬件中断和软件中断,8086可处理256种中断。
14. 8086可屏蔽中断请求输入线是什么?“可屏蔽”的涵义是什么?
答:硬件中断又可分为两类:可屏蔽中断和不可屏蔽中断。不可屏蔽中断:由NMI引脚引入,它不受中断允许标志IF的影响,每个系统中仅允许有一个,都是用来处理紧急情况的,如掉电处理。这种中断一旦发生,系统会立即响应;可屏蔽中断:由INTR引脚引入,它受中断允许标志IF的影响,也就是说,只有当IF=1时,可屏蔽中断才能进入,反之则不允许进入。
15. 中断向量表的功能是什么?已知中断类型码分别是84H和0FAH,它们的中断向量应放在中断向量表的什么位置?
答:中断向量表存放的是各中断程序的入口地址即16位偏移地址和16位段地址,只要给出中断类型码,可以算出中断程序在中断向量表的什么位置:
中断向量表地址=中断类型码*4 中断向量表地址1=84H*4=210H
中断向量表地址2=0FAH*4=3E8H
第3章 习题和解答
1. 简要分析8086的指令格式由哪些部分组成,什么是操作码?什么是操作数?寻址和寻址方式的含义是什么?8086指令系统有哪些寻址方式?
答:指令由操作码和操作数两部分组成,操作码表示计算机执行某种指令功能,操作数表示操作中所需要的数据或者数据所在存储单元的地址。
寻址方式是寻找操作数或操作数地址的方式。
8086提供了七种寻址方式:立即寻址、 寄存器寻址、直接寻址、寄存器间接寻址、 相对寄存器寻址、基址变址寻址和相对基址变址寻址方式。 2. 设(DS)=2000H,(ES)= 2100H,(SS)= 1500H,(SI)= 00A0H,(BX)= 0100H,(BP)= 0010H,数据变量VAL的偏移地址为0050H,请指出下列指令的源操作数字段是什么寻址方式?它的物理地址是多少?
(1) MOV AX,21H 立即寻址 物理地址无 (2) MOV AX,BX 寄存器寻址 物理地址无
(3) MOV AX,[1000H] 直接寻址 物理地址=2000H*10H+1000H=21000H (4) MOV AX,VAL 直接寻址 物理地址=2000H*10H+0050H=20050H (5) MOV AX,[BX] 寄存器间接寻址 物理地址=2000H*10H+0100H=20100H (6) MOV AX,ES:[BX] 寄存器间接寻址 物理地址=2100H*10H+0100H=21100H