计算机原理与接口技术课后习题答案.docx
《计算机原理与接口技术课后习题答案.docx》由会员分享,可在线阅读,更多相关《计算机原理与接口技术课后习题答案.docx(35页珍藏版)》请在冰点文库上搜索。
计算机原理与接口技术课后习题答案
第1章基础知识
1.1计算机中常用的计数制有哪些?
解:
二进制、八进制、十进制(BCD)、十六进制。
1.2请说明机器数和真值的区别。
解:
把符号数值化的数码称为机器数或机器码,原来的数值叫做机器数的真值。
1.3完成下列数制的转换。
解:
(1)166,A6H
(2)0.75(3)11111101.01B,FD.4H
(4)5B.AH,(10010001.011000100101)BCD
1.48位和16位二进制数的原码、补码和反码可表示的数的范围分别是多少?
解:
原码(-127~127)、(-32767~32767)
补码(-128~127)、(-32768~32767)
反码(-127~127)、(-32767~32767)
1.5写出下列真值对应的原码和补码的形式。
(1)X=-1110011B
(2)X=-71D(3)X=1001001B
解:
(1)原码:
11110011补码:
10001101
(2)原码:
11000111补码:
10111001
(3)原码:
01001001补码:
01001001
1.6写出符号数10110101B的反码和补码。
解:
11001010,11001011
1.7已知X和Y的真值,求[XY]的补码
(1)X=-1110111BY=1011010B
(2)X=56DY=-21D
解:
(1)11100011
(2)00100011
1.8已知X=-1101001B,Y=-1010110B,用补码求X-Y的值。
解:
[X-Y]补=11101101X-Y=-0010011B
1.9若给字符4和9的ASCII码加奇校验,应是多少?
若加偶校验?
解:
奇校验:
4:
(00110100B)34H,9:
(10111001B)B9H
偶校验:
4:
(10110100B)B4H,9:
(00111001B)39H
1.10若与门的输入端A、B、C的状态分别为1、0、1,则该与门的输出端状态为?
若将这3个信号连接到或门,那么或门的输出又是什么状态?
解:
1.11要使与非门输出“0”,则与非门输入端各位的状态应该是什
么?
如果使与非门输出“1”,其输入端各位的状态又应该是什么?
解:
全1;至少有一个0
1.12如果74LS138译码器的C、B、A三个输入端的状态为011,此时该译码器的8个输出端中哪一个会输出“0”?
解:
#Y3
1.13图1-16中,Y1=?
Y2=?
Y3=?
138译码器哪一个输出端会输出低电平?
解:
Y1=0;Y2=1;Y3=1;Y6
第2章微处理器和总线
2.2说明8086的EU和BIU的主要功能。
在执行指令期间,BIU能直接访问存储器吗?
解:
执行单元EU负责执行指令。
EU在工作时不断地从指令队列取出指令代码,对其译码后产生完成指令所需要的控制信息。
数据在ALU中进行运算,运算结果的特征保留在标志寄存器FLAGS中。
总线接口单元BIU负责CPU与存储器、I/O接口之间的信息传送。
BIU取出的指令被送入指令队列供EU执行,BIU取出的数据被送入相关寄存器中以便做进一步的处理。
在执行指令期间,BIU能直接访问存储器.因为EU和BIU可以并行工作,EU需要的指令可以从指令队列中获得,这时BIU预先从存储器中取出并放入指令队列的。
在EU执行指令的同时,BIU可以访问存储器取下一条指令或指令执行时需要的数据。
2.38088CPU工作在最小模式下:
(1)当CPU访问存储器时,要利用哪些信号?
(2)当CPU进行I/O操作时,要利用哪些信号?
(3)当HOLD有效并得到响应时,CPU的哪些信号置高阻?
解:
(1)要利用信号线包括#WR、#RD、IO/#M、ALE以及AD0~AD7、A8~A19。
(2)同
(1)。
(3)所有三态输出的地址信号、数据信号和控制信号均置为高阻态。
2.4总线周期中,什么情况下要插入TW等待周期?
插入TW周期的个数,取决于什么因素?
解:
在每个总线周期的T3的开始处若READY为低电平,则CPU在T3后插入一个等待周期TW。
在TW的开始时刻,CPU还要检查READY状态,若仍为低电平,则再插入一个TW。
此过程一直进行到某个TW开始时,READY已经变为高电平,这时下一个时钟周期才转入T4。
可以看出,插入TW周期的个数取决于READY电平维持的时间。
2.5若8088工作在单CPU方式下,在表2-5中填入不同操作时各控制信号的状态。
解:
结果如下所示。
2.6在8086/8088CPU中,标志寄存器包含哪些标志位?
各位为0(为1)分别表示什么含义?
解:
(略),见书第49页。
2.78086/8088CPU中,有哪些通用寄存器和专用寄存器?
说明它们的作用。
解:
通用寄存器包含以下8个寄存器:
AX、BX、CX和DX寄存器一般用于存放参与运算的数据或运算的结果。
除此之外:
AX:
主要存放算术逻辑运算中的操作数,以及存放I/O操作的数据。
BX:
存放访问内存时的基地址。
CX:
在循环和串操作指令中用作计数器。
DX:
在寄存器间接寻址的I/O指令中存放I/O地址。
在做双字长乘除法运算时,DX与AX合起来存放一个双字长数。
SP:
存放栈顶偏移地址。
BP:
存放访问内存时的基地址。
SP和BP也可以存放数据,但它们的默认段寄存器都是SS。
SI:
常在变址寻址方式中作为源地址指针。
DI:
常在变址寻址方式中作为目标地址指针。
专用寄存器包括4个段寄存器和两个控制寄存器:
CS:
代码段寄存器,用于存放代码段的段基地址。
DS:
数据段寄存器,用于存放数据段的段基地址。
SS:
堆栈段寄存器,用于存放堆栈段的段基地址。
ES:
附加段寄存器,用于存放附加段的段基地址。
IP:
指令指针寄存器,用于存放下一条要执行指令的偏移地址。
FLAGS:
标志寄存器,用于存放运算结果的特征。
2.88086/8088系统中,存储器为什么要分段?
一个段最大为多少个字节?
最小为多少个字节?
解:
分段的主要目的是便于存储器的管理,使得可以用16位寄存器来寻址20位的内存空间。
一个段最大为64KB,最小为16B。
2.9在8086/8088CPU中,物理地址和逻辑地址是指什么?
已知逻辑地址为1F00:
38A0H,如何计算出其对应的物理地址?
解:
物理地址时CPU存取存储器所用的地址。
逻辑地址是段和偏移地址形式的地址,即汇编语言程序中使用的存储器地址。
若已知逻辑地址为1F00:
38A0H,则对应的物理地址=1F00Hx1638A0H=228A0H。
2.10若CS=8000H,则当前代码段可寻址的存储空间的范围是多少?
解(CS)=8000H时,当前代码段可寻址的存储空间范围为80000H~8FFFFH。
第3章8088/8086指令系统
3.1什么叫寻址方式?
8086/8088CPU共有哪几种寻址方式?
解:
寻址方式主要是指获得操作数所在地址的方法.8086/8088CPU具有:
立即寻址、直接寻址、寄存器寻址、寄存器间接寻址、寄存器相对寻址、基址一变址寻址、基址一变址-相对寻址以及隐含寻址等8种寻址方式。
3.2设(DS)=6000H,(ES)=2000H,(SS)=1500H,(SI)=00A0H,(BX)=0800H,(BP)=1200H,字符常数VAR为0050H.请分别指出下列各条指令源操作数的寻址方式,并计算除立即寻址外的其他寻址方式下源操作数的物理地址是多少?
(1)MOVAX,BX
(2)MOVDL,80H
(3)MOVAX,VAR(4)MOVAX,VAR[BX][SI]
(5)MOVAL,'B'(6)MOVDI,ES:
[BX]
(7)MOVDX,[BP](8)MOVBX,20H[BX]
解:
(1)寄存器寻址。
因源操作数是寄存器,故寄存器BX就是操作数的地址.
(2)立即寻址。
操作数80H存放于代码段中指令码MOV之后。
(3)直接寻址。
(4)基址一变址一相对寻址.
操作数的物理地址=(DS)×16+(SI)+(BX)+VAR
=60000H+00A0H+0800H+0050H=608F0H
(5)立即寻址
(6)寄存器间接寻址.
操作数的物理地址=(ES)×16+(BX)
=20000H+0800H=20800H
(7)寄存器间接寻址。
操作数的物理地址=(SS)×16+(BP)
=15000H+1200H=16200H
(8)寄存器相对寻址.
操作数的物理地址=(DS)×16+(BX)+20H
=60000H+0800H+20H=60820H
3.3假设(DS)=212AH,(CS)=0200H,(IP)=1200H,(BX)=0500H,位移量DATA=40H,[217A0H]=2300H,[217E0H]=0400H,[217E2H]=9000H
试确定下列转移指令的转移地址.
(1)JMP2300H
(2)JMPWORDPTR[BX]
(3)JMPDWORDPTR[BXDATA]
解:
转移指令分为段内转移和段间转移,根据其寻址方式的不同,又有段内的直接转移和间接转移,以及段间的直接转移和间接转移地址。
对直接转移,其转移地址为当前指令的偏移地址(即IP的内容)加上位移量或由指令中直接得出;对间接转移,转移地址等于指令中寄存器的内容或由寄存器内容所指向的存储单元的内容。
(1)段内直接转移。
转移的物理地址=(CS)×l62300H
=02000H2300H=04300H
(2)段内间接转移。
转移的物理地址=(CS)×16[BX]
=(CS)×l6[217A0H]
=02000H2300H=04300H
(3)段间间接转移。
转移的物理地址=[BXDATA]
=[217E2H]×l6[217E0H]
=90000H0400H=90400H
3.4试说明指令MOVBX,5[BX]与指令LEABX,5[BX]的区别。
解:
前者是数据传送类指令,表示将数据段中以(BX5)为偏移地址的16位数据送寄存器BX.
后者是取偏移地址指令,执行的结果是(BX)=(BX)+5,即操作数的偏移地址为(BX)5。
3.5设堆栈指针SP的初值为2300H,(AX)=50ABH,(BX)=1234H。
执行指令PUSHAX后,(SP)=?
,再执行指令PUSHBX及POPAX之后,(SP)=?
(AX)=?
(BX)=?
解:
堆栈指针SP总是指向栈顶,每执行一次PUSH指令SP-2,执行一次POP指令SP2.所以,执行PUSHAX指令后,(SP)=22FEH;再执行PUSHBX及POPAX后,(SP)=22FEH,(AX)=(BX)=1234H
3.6指出下列指令的错误:
(1)MOVAH,CX
(2)MOV33H,AL
(3)MOVAX,[SI][DI](4)MOV[BX],[SI]
(5)ADDBYTEPTR[BP],256(6)MOVDATA[SI],ES:
AX
(7)JMPBYTEPTR[BX](8)OUT230H,AX
(9)MOVDS,BP(10)MUL39H
解:
(1)指令错。
两操作数字长不相等
(2)指令错。
MOV指令不允许目标操作数为立即数.
(3)指令错。
在间接寻址中不允许两个间址寄存器同时为变址寄存器。
(4)指令错。
MUV指令不允许两个操作数同时为存储器操作数。
(5)指令错。
ADD指令要求两操作数等字长。
(6)指令错。
源操作数形式错,寄存器操作数不加段重设符。
(7)指令错。
转移地址的字长至少应是16位的。
(8)指令错。
对输人输出指令,当端口地址超出8位二进制数的表达范围(即寻址的端口超出256个)时,必须采用间接寻址。
(9)指令正确。
(10)指令错。
MUL指令不允许操作数为立即数。
3.7已知(AL)=7BH,(BL)=38H,试问执行指令ADDAL,BL后,AF、CF、OF、PF、SF和ZF的值各为多少?
解:
AF=1,CF=0,OF=1,PF=0,SF=l,ZF=0
3.8试比较无条件转移指令、条件转移指令、调用指令和中断指令有什么异同?
解:
无条件转移指令的操作是无条件地使程序转移到指定的目标地址,并从该地址开始执行新的程序段,其转移的目标地址既可以是在当前逻辑段,也可以是在不同的逻辑段;条件转移指令是在满足一定条件下使程序转移到指定的目标地址,其转移范围很小,在当前逻辑段的-128~127地址范围内。
调用指令是用于调用程序中常用到的功能子程序,是在程序设计中就设计好的。
根据所调用过程人口地址的位置可将调用指令分为段内调用(入口地址在当前逻辑段内)和段间调用。
在执行调用指令后,CPU要保护断点。
对段内调用是将其下一条指令的偏移地址压人堆栈,对段间调用则要保护其下一条指令的偏移地址和段基地址,然后将子程序人口地址赋给IP(或CS和IP).
中断指令是因一些突发事件而使CPU暂时中止它正在运行的程序,转去执行一组专门的中断服务程序,并在执行完后返回原被中止处继续执行原程序。
它是随机的。
在响应中断后CPU不仅要保护断点(即INT指令下一条指令的段地址和偏移地址),还要将标志寄存器FLAGS压入堆栈保存。
3.9试判断下列程序执行后,BX中的内容.
MOVCL,3
MOVBX,0B7H
ROLBX,1
RORBX,CL
解:
该程序段是首先将BX内容不带进位循环左移1位,再循环右移3位。
即相当于将原BX内容不带进位循环右移2位,故结果为:
(BX)=0C02DH
3.10按下列要求写出相应的指令或程序段。
(1)写出两条使AX内容为0的指令。
(2)使BL寄存器中的高4位和低4位互换。
(3)屏蔽CX寄存器的bll,b7和b3位。
(4)测试DX中的b0和b8位是否为1。
解:
(1)MOVAX,0XORAX,AX;AX寄存器自身相异或,可使其内容清0
(2)MOVCL,4ROLBL,CL;将BL内容循环左移4位,可实现其高4位和低4位的互换(3)ANDCX,0F777H;将CX寄存器中需屏蔽的位“与”0。
也可用 “或”指令实现(4)ANDDX,0101H;将需侧试的位“与”1,其余“与”0屏蔽掉
CMPDX,0101H;与0101H比较
JZONE;若相等则表示b0和b8位同时为1
3.11分别指出以下两个程序段的功能:
(1)
(2)
MOVCX,l0CLD
LEASI,FIRSTLEADI,[1200H]
LEADI,SECONDMOVCX,0FOOH
STDXORAX,AX
REPMOVSBREPSTOSW
解:
(1)该段程序的功能是:
将数据段中FIRST为最高地址的10个字节数据按减地址方向传送到附加段SECOND为最高地址的向前10个单元中。
(2)将附加段中偏移地址为1200H单元开始的0FOOH个字单元清0。
3.12执行以下两条指令后,标志寄存器FLAGS的六个状态位各为什么状态?
MOVAX,84A0H
ADDAX,9460H
解:
执行ADD指令后,6个状态标志位的状态分别为:
在两个16位数进行加法运算时,对CF、ZF、SF和OF会产生影响,但对PF和AF标志位,只有其低8位的运算影响它们的状态。
各标志位的状态分别为:
AF=0,PF=1,CF=1,ZF=0,SF=0,OF=1。
3.13将46和-38分别乘以2,可应用什么指令来完成?
如果除以2呢?
解:
因为对二进制数,每左移一位相当于乘以2,右移一位相当于除以2。
所以,将46和-38分别乘以2,可分别用逻辑左移指令(SHL)和算术左移指令(SAL)完成。
SHL指令针对无符号数,SAL指令针对有符号数。
当然,也可以分别用无符号数乘法指令MUL和有符号数乘法指令IMUL完成。
如果是除以2,则进行相反操作,即用逻辑右移指令SHR或无符号数除法指令DIV实现46除以2的运算,用算术右移指令SAR或有符号数除法指令IDIV实现-38除以2的运算。
3.14已知AX=8060H,DX=03F8H,端口PORT1的地址是48H,内容为40H;PORT2的地址是84H,内容为85H。
请指出下列指令执行后的结果。
(1)OUTDX,AL
(2)INAL,PORT1
(3)OUTDX,AX
(4)INAX,48H
(5)OUTPORT2,AX
解:
(1)将60H输出到地址为03F8H的端口中。
(2)从PORT1读入一个字节数据,执行结果:
(AL)=40H。
(3)将AX=8060H输出到地址为03F8H的端口中。
(4)由48H端口读人16位二进制数。
(5)将8060H输出到地址为84H的端口中。
第4章汇编语言程序设计
4.1请分别用DB、DW、DD伪指令写出在DATA开始的连续8个单元中依次存放数据11H、22H、33H、44H、55H、66H、77H、88H的数据定义语句.
解:
DB,DW,DD伪指令分别表示定义的数据为字节类型、字类型及双字型.其定义形式为:
DATADB11H,22H,33H,44H,55H,66H,77H,88H
DATADW2211H,4433H,6655H,8877H
DATADD44332211H,88776655H
4.2若程序的数据段定义如下,写出各指令语句独立执行后的结果:
DSEGSEGMENT
DATA1DB10H,20H,30H
DATA2DW10DUP(?
)
STRINGDB‘123’
DSEGENDS
(1)MOVAL,DATA1
(2)MOVBX,OFFSETDATA2
(3)LEASI,STRING
ADDDI,SI
解:
(1)取变量DATA1的值.指令执行后,(AL)=10H.
(2)变量DATA2的偏移地址.指令执行后,(BX)=0003H.
(3)先取变量STRING的偏移地址送寄存器SI,之后送SI的内容与DI的内容相加并将结果送DI.指令执行后,(SI)=0017H;(DI)=(DI)0017H.
4.3试编写求两个无符号双字长数之和的程序.两数分别在MEM1和MEM2单元中,和放在SUM单元.
解:
DSEGSEGMENT
MEM1DW1122H,3344H
MEM2DW5566H,7788H
SUMDW2DUP(?
)
DSEGENDS
CSEGSEGMENT
ASSUMECS:
CSEG,DS:
DSEG
START:
MOVAX,DSEG
MOVDS,AX
LEABX,MEM1
LEASI,MEM2
LEADI,SUM
MOVCL,2
CLC
AGAIN:
MOVAX,[BX]
ADCAX,[SI]
MOV[DI],AX
ADDBX,2
ADDSI,2
ADDDI,2
LOOPAGAIN
HLT
CSEGENDS
ENDSTART
4.4试编写程序,测试AL寄存器的第4位(bit4)是否为0?
解:
测试寄存器AL中某一位是否为0,可使用TEST指令、AND指令、移位指令等几种方法实现。
如:
TESTAL,10H
JZNEXT
.
.
.
NEXT:
…
或者:
MOVCL,4
SHLAL,CL
JNCNEXT
.
NEXT:
…
4.5试编写程序,将BUFFER中的一个8位二进制数转换为ASCII码,并按位数高低顺序存放在ANSWER开始的内存单元中。
解:
DSEGSEGMENT
BUFFERDB?
ANSWERDB3DUP(?
)
DSEGENDS
CSEGSEGMENT
ASSUMECS:
CSEG,DS:
DSEG
START:
MOVAX,DSEG
MOVDS,AX
MOVCX,3;最多不超过3为十进制数(255)
LEADI,ANSWER;DI指向结果存放单元
XORAX,AX
MOVAL,BUFFER;取要转换的二进制数
MOVBL,0AH;基数10
AGAIN:
DIVBL;用除10取余的方法转换
ADDAH,30H;十进制数转换成ASCII码
MOV[DI],AH;保存当前的结果
INCDI;指向下一个位保存单元
ANDAL,AL;商为0?
(转换结束?
)
JZSTO;若结束,退出
MOVAH,0
LOOPAGAIN;否则循环继续
STO:
MOVAX,4C00H
INT21H;返回DOS
CSEGENDS
ENDSTART
4.6假设数据项定义如下:
DATA1DB‘HELLO!
GOODMORNING!
’
DATA2DB20DUP(?
)
用串操作指令编写程序段,使其分别完成以下功能:
(1)从左到右将DATA1中的字符串传送到DATA2中。
(2)传送完后,比较DATA1和DATA2中的内容是否相同。
(3)把DATA1中的第3和第4个字节装入AX。
(4)将AX的内容存入DATA25开始的字节单元中。
解:
(1)
MOVAX,SEGDATA1
MOVDS,AX
MOVAX,SEGDATA2
MOVES,AX
LEASI,DATA1
LEADI,DATA2
MOVCX,20
CLD
REPMOVSB
(2)
LEASI,DATA1
LEADI,DATA2
MOVCX,20
CLD
REPECMPSB
。
。
。
(3)
LEASI,DATA1
ADDSI,2
LODSW
(4)LEADI,DATA2
ADDDI,5
STOSW
4.7执行下列指令后,AX寄存器的内容是多少?
TABLEDW10,20,30,40,50
ENTRYDW3
.
.
.
MOVBX,OFFSETTABLE
ADDBX,ENTRY
MOVAX,[BX]
解:
(AX)=1E00H
4.8编写程序段,将STRING1中的最后20个字符移到STRING2中(顺序不变)。
解:
首先确定STRING1中字符串的长度,因为字符串的定义要求以‘$’符号结尾,
可通过检测‘$’符确定出字符串的长度,设串长度为COUNT,则程序如下:
LEASI,STRING1
LEADI,STRING2
ADDSI,COUNT-20
MOVCX,20
CLD
REPMOVSB
4.9假设一个48位数存放在DX:
AX:
BX中,试编写程序段,将该48位数乘以2.
解:
可使用移位指令来实现。
首先将BX内容逻辑左移