微机原理与接口技术基于8086和Proteus仿真第2版习题参考答案.docx
《微机原理与接口技术基于8086和Proteus仿真第2版习题参考答案.docx》由会员分享,可在线阅读,更多相关《微机原理与接口技术基于8086和Proteus仿真第2版习题参考答案.docx(40页珍藏版)》请在冰豆网上搜索。
微机原理与接口技术基于8086和Proteus仿真第2版习题参考答案
1.答:
为了区别所使用的数制,一般用以下两种书写格式表示:
①用括号将数字括起,后面加数制区分,数制用下标的形式给出;
②用后缀区分,二进制数、十进制数、八进制数、十六进制数的后缀分别为字母B〔或b、D〔或d、O〔或o或Q〔或q、H〔或h。
例如:
十六进制数56.78可以表示成<56.78>16或56.78H;
十进制数56.78可以表示成<56.78>10或56.78D。
2.答:
123D采用十进制,0AFH采用十六进制,77Q采用八进制,1001110B采用二进制。
3.答:
字长为8位的二进制数原码表示的最大值:
127,最小值:
-127;补码表示的最大值:
127,最小值:
-128。
字长为16位的二进制数原码表示的最大值:
32767,最小值:
-32767;补码表示的最大值:
32767,最小值:
-32768。
4.答:
<1>125D=01111101B=7DH
<2>255D=11111111B=FFH
<3>72D=01001000B=48H
<4>5090D=0001001111100010B=13E2H
5.答:
<1>11110000B=240D=F0H
<2>10000000B=128D=80H
<3>11111111B=255D=FFH
<4>01010101B=85D=55H
6.答:
<1>FFH=255D=11111111B
<2>ABCDH=43947D=1010101111001101B
<3>123H=291D=0000000100100011B
<4>FFFFH=65535D=1111111111111111B
7.答:
<1>8位时<16>原=00010000;<16>补=00010000;
16位时<16>原=0000000000010000;<16>补=0000000000010000;
<2>8位时<-16>原=10010000;<-16>补=11110000;
16位时<-16>原=1000000000010000;<-16>补=1111111111110000;
<3>8位时<+0>原=00000000;<+0>补=00000000;
16位时<+0>原=0000000000000000;<+0>补=0000000000000000;
<4>8位时<-0>原=10000000;<-0>补=00000000;
16位时<-0>原=1000000000000000;<-0>补=0000000000000000;
<5>8位时<127>原=01111111;<127>补=01111111;
16位时<127>原=0000000001111111;<127>补=0000000001111111;
<6>8位时-128超过原码表示的范围;<-128>补=10000000;
16位时<-128>原=1000000010000000;<-128>补=1111111110000000;
<7>8位时<121>原=01111001;<121>补=01111001;
16位时<121>原=0000000001111001;<121>补=0000000001111001;
<8>8位时<-9>原=10001001;<-9>补=11110111;
16位时<-9>原=1000000000001001;<-9>补=1111111111110111;
8.答:
〔1[x]补=11000010;〔2[-x]补=00001101;〔3[x]原=11000010;〔4[x]反=10111101。
9.答:
〔1A>B;〔2A<B
10.答:
〔1溢出;〔213H;〔3溢出;〔4EDH;〔5EDH。
11.答:
〔110001000;〔211101110;〔301100110;〔410101100;
〔500000000;〔610101100;〔7=01010011。
12.答:
〔130H=48,字符为‘0’;〔239H=57,字符为‘9’;〔342H=66,字符为‘B’;
〔462H=98,字符为‘b’;〔520H=32,字符为空格;〔67H=7,字符为报警符;
13、答:
十进制
49
123
7
62
压缩BCD码
01001001B
000100100011B
00000111B
01100010B
非压缩BCD码
0000010000001001B
000000010000001000000011B
00000111B
0000011000000010B
ASCII码
3439H
313233H
37H
3632H
1.〔1答:
物理地址:
物理地址〔PA是20位无符号二进制数,是CPU访问存储器的实际地址。
每个存储单元对应一个物理地址。
8086存储空间的物理地址范围是:
00000H~FFFFFH。
逻辑地址:
采用分段结构的存储器中,把通过段地址和偏移地址来表示的存储单元的地址称为逻辑地址,记为:
段地址:
偏移地址。
段地址:
8086规定各逻辑段从节的整数边界开始,即段首地址二进制值的低4位是0000,把段首地址的高16位称为段基址或段地址。
偏移地址:
把某一存储单元相对于段地址的段内偏移量称为偏移地址〔也称有效地址EA。
段地址和偏移地址都是是16位无符号二进制数。
〔2答:
时钟周期:
计算机的"时钟"是由振荡源产生的、幅度和周期不变的节拍脉冲,每个脉冲周期称为时钟周期,又称为T状态或T周期,时钟周期是微机系统工作的最小时间单元。
总线周期:
当CPU访问存储器或输入/输出端口时,需要通过总线进行读或写操作,这个过程称为总线周期〔BusCycle。
总线周期是利用总线完成一次读/写所需要的时间。
指令周期:
执行一条指令所需要的时间称为指令周期〔InstructionCycle。
指令周期由1个或多个总线周期组成。
〔3答:
最小模式:
也称为单处理器模式,是指系统中只有一片8086微处理器,所连接的存储器容量不大、片子不多,所要连接的I/O端口也不多,系统的控制总线就直接由CPU的控制线供给,从而使得系统中的总线控制电路减到最少。
最小模式适用于较小规模的系统。
最大模式:
相对于最小模式而言,适用于中、大型规模的系统。
系统中有多个微处理器,其中一个是主处理器8086,其他的处理器称为协处理器,承担某方面专门的工作。
需要增加一片8288来对8086CPU发出的控制信号进行变换和组合,以得到对存储器或I/O端口的读/写信号和对锁存器、总线收发器的控制信号。
2.答:
EU:
负责指令的执行,即从总线接口部件BIU的指令队列取指令,指令执行后向BIU送回运算结果,同时把运算结果的状态特征保存到标志寄存器中。
BIU:
负责CPU与存储器、I/O设备之间的数据传送。
BIU完成以下操作:
取指令送给指令队列、配合执行部件从指定的内存单元或者外设端口中取数据、将数据传送给执行部件或者把执行部件的操作结果传送到指定的内存单元或外设端口中。
8086的BIU和EU在很多时候可以并行工作,使得取指令、指令译码和执行指令这些操作构成操作流水线。
①当指令队列中有两个空字节,且EU没有访问存储器和I/O接口的要求时,BIU会自动把指令取到指令队列中。
②当EU准备执行一条指令时,它会从指令队列前部取出指令执行。
在执行指令的过程中,如果需要访问存储器或者I/O设备,那么EU会向BIU发出访问总线的请求,以完成访问存储器或者I/O接口的操作。
如果此时BIU正好处于空闲状态,那么,会立即响应EU的总线请求;但如果BIU正在将某个指令字节取到指令队列中,那么,BIU将首先完成这个取指令操作,然后再去响应EU发出的访问总线的请求。
③当指令队列已满,而且EU又没有总线访问时,BIU便进入空闲状态。
④在执行转移指令、调用指令和返回指令时,下面要执行的指令就不是在程序中紧接着的那条指令了,而BIU往指令队列装入指令时,总是按顺序进行的。
在这种情况下,指令队列中已经装入的指令就没有用了,会被自动消除。
随后,BIU会往指令队列中装入另一个程序段中的指令。
3.答:
地址信号是CPU发送给内存或I/O设备的,所以地址线是单向的;
数据信号可以从CPU发送给内存或I/O设备,也可以从内存或I/O设备发送给CPU,故而数据线是双向的。
4.答:
8086CPU中有14个寄存器。
它们是:
4个16位的通用寄存器:
AX、BX、CX、DX和8个8位的通用寄存器:
AH、AL、BH、BL、CH、CL、DH、DL;指针和变址寄存器SP、BP、SI、DI;4个16位的段寄存器CS、DS、SS和ES;标志寄存器FR;指令指针寄存器IP。
功能略。
5.答:
〔1加法运算的结果为:
CEACH;CF=0,PF=1,AF=0,ZF=0,SF=1,OF=1;
〔2加法运算的结果为:
68ACH;CF=0,PF=1,AF=0,ZF=0,SF=0,OF=0;
〔3加法运算的结果为:
DDDDH;CF=0,PF=1,AF=0,ZF=0,SF=1,OF=0。
6.答:
8086CPU可寻址的存储器地址范围是00000H~FFFFFH;
可寻址的I/O端口地址范围是0000H~FFFFH。
7.答:
由于8086CPU提供20位地址,但8086中可用来存放地址的寄存器,如IP、SP、BX、SI等都是16位的,只能直接寻址64KB。
为了寻址1MB存储空间,8086CPU采用了典型的存储器分段技术,即将整个存储器空间分为许多逻辑段,每个逻辑段的容量小于或等于64KB。
分段后,对存储器的寻址操作不再直接用20位的物理地址,而是采用段地址加段内偏移地址的二级寻址方式。
8.答:
将AH的内容送存储单元的操作过程中:
;
将I/O端口的内容送AL的操作过程中:
。
9.答:
A0
有效的数据引脚
操作
00
AD15~AD0〔一个总线周期同时访问奇体和偶体,从奇地址单元读/写字数据的高8位,从偶地址单元读/写字数据的低8位
从偶地址读/写一个字
10
AD7~AD0
从偶地址读/写一个字节
01
AD15~AD8
从奇地址读/写一个字节
01
10
AD15~AD8〔第一个总线周期从奇字数据的低8位
AD7~AD0〔第二个总线周期从偶地址单元读/写字数据的高8位
从奇地址读/写一个字
10.答:
8086系统复位后,指令指针〔IP为0000H;CS寄存器为FFFFH,其他寄存器为0000H;指令队列清空。
11.答:
8086的A19/S6~A16/S3和AD15~AD0是复用信号,需要地址锁存器将地址信息保存起来,为外接存储器或外设提供地址信息。
需要锁存的信号是:
地址信号及
信号。
12.答:
8086CPU一个基本的总线周期包含4个时钟周期:
T1、T2、T3和T4。
在T1状态,
有效,指示CPU访问的是存储器还是外设,之后CPU往多路复用总线上发出地址信息,以指出要寻址的存储单元或外设端口的地址。
在T1状态,CPU还必须在ALE引脚上输出一个正脉冲作为地址锁存信号。
信号也在T1状态送出,它用来表示数据传送的字宽。
在T2状态,CPU从总线上撤销地址,使总线的低16位浮空,置成高阻状态,为传输数据作准备。
总线的最高4位〔A19~A16用来输出本总线周期的状态信息。
读信号
或写信号
在T2状态变为有效,指示CPU将进行哪种操作〔读或写。
在T3状态,多路总线的高4位继续提供状态信息,而多路总线的低16位上出现由CPU读出的数据或者CPU从存储器或端口写入的数据。
在T4状态和前一个状态的交界处,CPU对数据总线进行采样,获得数据,总线周期结束。
13.答:
在有些情况下,外设或存储器速度较慢,不能及时地配合CPU传送数据。
这时,外设或存储器会通过"READY"信号线在T3状态启动之前向CPU发一个"数据未准备好"信号,于是CPU会在T3之后插入1个或多个附加的时钟周期TW。
取决与外设或存储器速度。
14.答:
两种操作时序的不同之处发生在T1和T2状态。
①在T1状态,读周期:
应输出低电平;写周期:
应输出高电平。
②在T2状态,读周期:
有效,而
无效,AD15~AD0为高阻态;写周期:
变为无效,而写信号
变为有效,AD15~AD0在地址撤销之后立即送出要写入存储器或外设端口的数据。
15.答:
在最小模式下,读信号
、ALE和
、
等信号直接由CPU给出;
在最大模式下,总线控制器8288根据
和
状态信号产生读信号
和
ALE和
、DEN也是由8288发出的,而且DEN信号的极性与CPU在最小模式下发出的
信号正好相反。
1.答:
指令中关于如何求出操作数有效地址的方法称为寻址方式。
8086CPU支持多种寻址方式,根据操作数的类型及来源大致分为3类:
数据寻址、转移地址寻址和I/O寻址。
2.答:
8086汇编指令可以采用7种基本的数据寻址方式:
①立即寻址;②寄存器寻址;③直接寻址;④寄存器间接寻址;⑤寄存器相对寻址;⑥基址变址寻址;⑦相对基址变址寻址。
与存储器寻址方式〔后5种相比,寄存器寻址方式最快。
3.答:
如果指令中没有用前缀说明操作数存放在哪个段,则操作数默认存放在数据段。
8086系统允许操作数存放在代码段、堆栈段或附加段。
此时,就需要在指令中利用前缀指明段超越。
例如:
MOVES:
[1225H],AX
4.答:
〔1寄存器寻址方式
〔2寄存器间接寻址方式,PA=10300H
〔3寄存器间接寻址方式,PA=20200H
〔4直接寻址方式,PA=10060H
〔5基址变址寻址方式,PA=10500H
〔6相对基址变址寻址方式,PA=12300H
〔7直接寻址方式,PA=11000H
〔8寄存器相对寻址方式,PA=10306H
〔9直接寻址方式,PA=10065H
5.答:
〔1
〔2
〔3
〔4
〔5
〔6
〔7
〔8
〔9
〔10
〔11
×
×
×
√
×
√
×
×
√
×
×
6.答:
〔1源操作数的寻址方式不同。
MOVAX,3000H指令的源操作数采用的是立即数寻址方式,MOVAX,[3000H]指令的源操作数采用的是直接寻址方式。
〔2指令执行后,AX的值不同。
MOVAX,MEM指令执行后,AX得到的是MEM单元的内容,而MOVAX,OFFSETMEM指令执行后,AX得到的是MEM单元的地址。
〔3指令不同。
MOVAX,MEMMOVAX,MEM指令执行后,AX得到的是MEM单元的内容,而LEAAX,MEM指令执行后,AX得到的是MEM单元的地址。
〔4转移的类型不同。
JMPSHORTL1指令实现的是段内转移,而JMPNEARPTRL1指令实现的是段间转移。
〔5指令的执行结果不同。
CMPDX,CX指令执行后,DX的值不变,而SUBDX,CX指令执行后,DX的值是两寄存器值的差。
〔6操作数所在段不同。
MOV[BP][SI],CL指令访问的是堆栈段的存储单元,而MOVDS:
[BP][SI],CL指令访问的是数据段的存储单元。
7.答:
〔1MOVBYTEPTR[BP],200指令执行后,〔58200H=200H
〔2MOVWORDPTR[BX],2000指令执行后,〔22400H=2000H
8.答:
当前栈顶地址是:
FE00H:
2010H;
执行PUSHBX指令后,栈顶地址变为:
FE00H:
200EH,栈顶2字节内容是:
3457H。
9.答:
〔1〔DX=3C62H,CF=1
〔2〔DX=03C6H,CF=0
〔3〔DX=18A0H,CF=1
〔4〔DX=2BC6H,CF=0
〔5〔DX=18B7H,CF=1
〔6〔DX=BCC5H,CF=0
10.答:
〔AX
CF
ZF
OF
SF
PF
<1>
134EH
0
0
0
0
1
<2>
0821H
0
0
0
0
1
<3>
F142H
1
0
0
1
1
<4>
0A69
1
0
0
1
1
<5>
F596
-
-
-
-
-
<6>
0A69
0
0
0
0
1
11.答:
<1>CMPCX,DX
JANEXT
<2>CMPAX,BX
JNANEXT
<3>CMPDX,0
JZNEXT
<4>CMPCX,DX
ENEXT
12.答:
(1)程序转向L1。
(2)程序转向L1。
(3)程序转向L2。
(4)程序转向L5。
(5)程序转向L5。
13.答:
因为普通运算指令执行的是二进制数的运算,而BCD码是十进制数,所以,需要对运算结果进行十进制调整。
在做BCD码的加、减和乘法运算时,十进制调整指令放在运算指令之后;而作BCD码的除法运算时,在运算指令之前用十进制调整指令对被除数进行调整。
14.答:
MOVCl,3
SHRbx,cl
15.答:
〔略
16.答:
DATASEGMENT
COUNT=100H
ORG1000H
D_DATADBCOUNTDUP
>
ORG2170H
S_DATADBCOUNT/5DUP<1,2,3,4,5>
DATAENDS
CODESEGMENT
ASSUMECS:
CODE,DS:
DATA,ES:
DATA
START:
MOVAX,DATA
MOVDS,AX
MOVES,AX
LEASI,S_DATA
LEADI,D_DATA
MOVCX,COUNT
REPMOVSB
MOVAL,1
MOVCX,COUNT
LEADI,D_DATA
AGAIN:
CMPBYTEPTR[DI],AL
JNZNEXT
MOVBYTEPTR[DI],''
NEXT:
INCDI
LOOPAGAIN
EXIT:
MOVAH,4CH
INT21H
CODEENDS
ENDSTART
17.答:
CODESEGMENT
ASSUMECS:
CODE
START:
MOVAX,5678H
MOVDX,1234H
NOTAX
NOTDX
ADDAX,1
ADCDX,0
EXIT:
MOVAH,4CH
INT21H
CODEENDS
ENDSTART
18.答:
19.答:
20.答:
21.答:
22.答:
23.答:
24.答:
25.答:
JMPSHORTLAB指令是一条双字节指令。
这条指令取出后,=0102H,转移目标的偏移地址=+位移量。
所以,转移目标的物理地址=╳16++位移量。
〔1转移目标的物理地址=╳16+0158H
〔2转移目标的物理地址=╳16+0182H
〔3转移目标的物理地址=╳16+017AH
〔4转移目标的物理地址=╳16+01E2H
26.答:
27.答:
28.答:
29.答:
1.答:
标号是指令的符号地址,可用作控制转移指令的操作数。
标号具有3种属性:
段属性、偏移属性和类型属性。
2.答:
变量是存储单元的符号地址。
变量具有3种属性:
段属性、偏移属性和类型属性。
3.答:
伪指令语句,也称指示性语句,是不可执行语句,汇编后不产生目标代码,它仅仅在汇编过程中告诉汇编程序如何汇编源程序。
宏是一个以宏名定义的指令序列。
一旦把某程序段定义成宏,则可以用宏名代替那段程序。
在汇编时,要对宏进行宏展开,即把以宏名表示的地方替换为该宏对应的指令序列的目标代码。
宏指令可以看成指令语句的扩展,相当于多条指令语句的集合。
4.答:
汇编语言表达式中有如下运算符:
算术操作符、逻辑操作符、移位操作符、关系操作符、数值回送操作符和属性操作符。
操作符所完成的运算在汇编阶段进行。
5.答:
略。
6.答:
〔1DB1DB10HDUP<1,2,5DUP<3>,4>
〔2DB2DB'STUDENT'
〔3BD3DW12H,0ABCDH
〔4COUNTEQUDB2-DB1
7.答:
第一个OR表示该指令是OR指令,在程序运行时,该OR操作被执行。
第二个OR是逻辑操作符OR,在汇编时,OR运算被执行。
8.答:
〔1〔AX=1
〔2〔AX=2
〔3〔CX=5
〔4〔DX=0AH
〔5〔CX=1
〔6〔DX=4
9.答:
略。
10.答:
11.答:
12.答:
13.答:
<3>
<4><2><5><1>
<6>
1B50H
1000H
1A70H
150BH
上表左侧的序号,表示对应操作完成后SP指向的栈顶的位置。
14.答:
15.答:
16.答:
17.~21.答:
略。
略。
1.半导体存储器的分类如下:
2.随机存取存储器RAM,又称为读/写存储器,其每个存储单元的内容可以随时按需要进行读/写操作。
RAM主要用来保存各种输入/输出数据、中间结果、与外存交换的信息,也可作堆栈使用。
而ROM的内容只能读出,不能写入或改写,一般用来存放固定的程序和数据。
3.半导体存储器的主要技术指标:
存储容量、读/写速度〔存取时间和存储周期、可靠性。
4.8086CPU和存储器连接时要考虑:
存储芯片数,AB、DB和一些控制信号的连接,奇、偶片的设置,地址译码方式等。
5.常用的存储器地址译码方式有:
全地址译码、部分地址译码、线选法。
6.需要<16k⨯8>/<1024⨯1>=128片,CPU地址线中片内寻址10位,片外4位。
7.
8.
1.I/O接口的功能:
对输入/输出数据进行缓冲和锁存、对信号的形式和数据的格式进行变换、对I/O端口进行寻址、提供联络信号等。
2.CPU与外设之间的数据传输方式有程序控制方式〔无条件传输方式和程序查询方式、中断方式、DMA、通道控制和I/O处理器。
无条件传输方式:
CPU不需要了解外设状态,直接与外设传输数据,适用于按钮开关、发光二极管等简单外设与CPU的数据传送过程。
程序查询方式:
CPU与外设传输数据之前,先检查外设状态,如果外设处于"准备好"状态〔输入设备或"空闲"状态〔输出设备,才可以传输数据。
中断方式:
外设在数据准备好之后再通知CPU,这样,CPU在没接到外设通知前只管做自己的事情,只有接到通知时才执行与外设的数据传输工作。
DMA:
直接存储器存取方式,将外设与内存间建立起直接的通道,CPU不再直接参加外设与内存间的数据传输,而是在系统需要进行DMA传输时,将CPU对地址总线、数据总线及控制总线的管理权交由DMA控制器进行控制。
通道控制和I/O处理器:
主CPU启动通道工