微机原理与接口技术楼顺天版课后习题答案14章.docx
- 文档编号:27433772
- 上传时间:2023-06-30
- 格式:DOCX
- 页数:93
- 大小:578.09KB
微机原理与接口技术楼顺天版课后习题答案14章.docx
《微机原理与接口技术楼顺天版课后习题答案14章.docx》由会员分享,可在线阅读,更多相关《微机原理与接口技术楼顺天版课后习题答案14章.docx(93页珍藏版)》请在冰豆网上搜索。
微机原理与接口技术楼顺天版课后习题答案14章
普通高等教育“十一五”国家级规划教材
微机原理与接口技术
[课后习题答案]
[楼顺天周佳社]编著
[科学出版社2010年6月第六次印刷版]
目录
第1章数制与码制2
第2章8086CPU结构与功能)7
第3章数制与码制9
第4章汇编语言程序设计24
第1章数制与码制
1.将下列十进制数转换成二进制数:
(1)58;
(2)67.625;(3)5721;
解:
(1)58D=00111010B
(2)67.625D=01000011.1010B
(3)5721D=0001011001011001B
2.将二进制数变换成十六进制数:
(1)10010101B;
(2)1101001011B;(3)1111111111111101B;
(4)0100000010101B;(5)01111111B;(6)010000000001B
解:
(1)10010101B=95H
(2)1101001011B=34BH
(3)1111111111111101B=FFFDH
(4)0100000010101B=815H
(5)01111111B=7FH
(6)010000000001B=401H
3.将十六进制数变换成二进制数和十进制数:
(1)78H;
(2)0A6H;(3)1000H;(4)0FFFFH
解:
(1)78H=120D=01111000B
(2)0A6H=166D=10100110B
(3)1000H=4096D=0001000000000000H
(4)0FFFFH=65535D=1111111111111111B
4.将下列十进制数转换成十六进制数:
(1)39;
(2)299.34375;(3)54.5625
解:
(1)39D=27H
(2)299.34375D=12B.58H
(3)54.5625D=36.9H
5.将下列二进制数转换成十进制数:
(1)10110.101B;
(2)10010010.001B;(3)11010.1101B
解:
(1)10110.101B=22.625D
(2)10010010.001B=146.125D
(3)11010.1101B=26.8125D
6.计算(按原进制运算):
(1)10001101B+11010B;
(2)10111B+11100101B;(3)1011110B-1110B;
(4)124AH+78FH;(5)5673H+123H;(6)1000H-F5CH;
解:
(1)10100111B
(2)11111100B
(3)1010000B
(4)19D9H
(5)5796H
(6)A4H
7.已知a=1011B,b=11001B,c=100110B,按二进制完成下列运算,并用十进制运算检查计算结果:
(1)a+b;
(2)c-a-b;(3)a×b;(4)c÷b
解:
a=1011B=11Db=11001B=25Dc=100110B=38D
(1)100100B=36D
(2)10B=2D
(3)100010011B=275D
(4)1B余1101B=13D
8.已知a=00111000B,b=11000111B,计算下列逻辑运算:
(1)aANDb;
(2)aORb;(3)aXORb;(4)NOTa
解:
(1)00000000B
(2)11111111B
(3)11111111B
(4)11000111B
9.设机器字长为8位,写出下列各数的原码和补码:
(1)+1010101B;
(2)-1010101B;(3)+1111111B;
(4)-1111111B;(5)+1000000B;(6)-1000000B
解:
(1)原01010101B补01010101B
(2)原11010101B补10101011B
(3)原01111111B补01111111B
(4)原11111111B补10000001B
(5)原01000000B补01000000B
(6)原11000000B补11000000B
10.写出下列十进制数的二进制补码表示(设机器字长为8位):
(1)15;
(2)-1;(3)117;(4)0;
(4)-15;(5)127;(6)-128;(7)80
解:
(1)(00001111B)补
(2)(11111111B)补
(3)(01110101B)补
(4)(00000000B)补
(5)(11110001B)补
(6)(01111111B)补
(7)(10000000B)补
(8)(01010000B)补
11.设机器字长为8位,先将下列各数表示成二进制补码,然后按补码进行运算,并用十进制数运算进行检验:
(1)87-73;
(2)87+(-73);(3)87-(-73);
(4)(-87)+73;(5)(-87)-73;(6)(-87)-(-73);
解:
(1)1110B=14D
(2)00001110B进位舍弃
(3)10100000B=-96D溢出
(4)11110010B=-14D
(5)01100000B=96D溢出
(6)11110010B=-14D
12.已知a,b,c,d为二进制补码:
a=00110010B,b=01001010B,c=11101001B,d=10111010B,计算:
(1)a+b;
(2)a+c;(3)c+b;(4)c+d;
(5)a-b;(6)c-a;(7)d-c;(8)a+d-c
解:
(1)01111100B
(2)00011011B
(3)00110011B
(4)10100011B
(5)11101000B
(6)10110111B
(7)11010001B
(8)11B
13.设下列四组为8位二进制补码表示的十六进制数,计算a+b和a-b,并判断其结果是否溢出:
(1)a=37H,b=57H;
(2)a=0B7H,b=0D7H;
(3)a=0F7H,b=0D7H;(4)a=37H,b=0C7H
解:
(1)a+b=8EH溢出,a-b=E0H未溢出
(2)8EH未溢出,E0H未溢出
(3)CEH未溢出,20H未溢出
(4)FEH未溢出70H未溢出
14.求下列组合BCD数的二进制和十六进制表示形式:
(1)3251
(2)12907(3)2006
解:
(1)0011001001010001B=3251H
(2)0001001010010111B=12907H
(3)0010000000000110B=2006H
15.将下列算式中的十进制数表示成组合BCD码进行运算,并用加6/减6修正其结果:
(1)38+42;
(2)56+77;(3)99+88;(4)34+69;
(5)38-42;(6)77-56;(7)15-76;(8)89-23
解:
(1)00111000B+01000010B=01111010B低BCD码位需要加6修正
01111010B+00000110B=10000000B=80BCD
(2)01010110B+01110111B=11001101B高、低BCD码位都需要加6修正
11001101B+01100110B=000100110011B=133BCD
(3)10011001B+10001000B=000100100001B高、低BCD码位都需要加6修正
000100100001B+01100110B=000110000111B=187BCD
(4)00110100B+01101001B=10011101B低BCD码位需要加6修正
10011101B+00000110B=10100011B修正结果使高BCD码位需要加6修正
10100011B+01100000B=000100000011B=103BCD
(5)00111000B-01000010B=(-1)11110110B高BCD码位需要减6修正
(-1)11110110B-01100000B=(-1)10010110B=-100+96=-4BCD
(6)01110111B-01010110B=00100001B=21BCD
(7)00011001B-01110110B=(-1)10011111B高、低BCD码位都需要减6修正
(-1)10011111B-01100110B=(-1)00111001B=-100+39=-61BCD
(8)10001001B-00100011B=01100110B=66BCD
16.将下列字符串表示成相应的ASCII码(用十六进制数表示):
(1)Example1;
(2)XiDianUniversity;(3)-108.652;
(4)Howareyou?
;(5)Computer(6)InternetWeb
解:
(1)45H,78H,61H,6DH,70H,6CH,65H,20H,31H
(2)58H,69H,44H,69H,61H,6EH,20H,55H,6EH,69H,76H,65H,72H,73H,69H,74H,79H
(3)2DH,31H,30H,38H,2EH,36H,35H,32H
(4)48H,6FH,77H,20H,61H72H,65H,20H79H,6FH,75H
(5)43H,6FH,6DH,70H,75H,74H,65H,72H
(6)49H,6EH,74H,65H72H,6EH,65H,74H,20H,57H,65H,62H
17.将下列字符串表示成相应的ASCII码(用十六进制数表示):
(1)Hello
(2)123
(4)Thenumberis2315
解:
(1)48H,65H,6CH,6CH,6FH
(2)31H,32H,33H,0DH,34H,35H,36H
(3)41H,53H,43H,49H,49H(4)54H,68H,65H,20H,6EH,75H,6DH,62H,65H,72H
第2章8086CPU结构与功能
1.微处理器内部结构由哪几部分组成?
阐述各部分的主要功能。
解:
微处理器内部结构由四部分组成:
(1)算术逻辑运算单元ALU:
完成所有的运算操作;
(2)工作寄存器:
暂存寻址信息和计算过程中的中间结果;
(3)控制器:
完成指令的读入、寄存和译码,并产生控制信号序列使ALU完成指定操作;
(4)I/O控制逻辑:
处理I/O操作。
2.微处理器级总线有哪几类?
各类总线有什么作用?
解:
微处理器级总线有三类:
(1)数据总线:
传送信息;
(2)地址总线:
传送地址码;
(3)控制总线传送控制信号。
3.为什么地址总线是单向的,而数据总线是双向的?
解:
地址码只能由CPU生成。
而数据需要在CPU和存储器之间传输。
4.8086/8088微处理器内部有哪些寄存器?
其主要作用是什么?
解:
8086CPU内部有14个16位寄存器,其中8个通用寄存器(4数据寄存器AX、BX、CX、DX,4地址指针/变址寄存器SI、DI、SP、BP),4个段寄存器(CS、DS、ES、SS),2个控制寄存器(指令指针IP,微处理器状态字PSW)。
应该注意的是:
可以在指令中用作为地址指针的寄存器有:
SI、DI、BP和BX;在微处理器状态字PSW中,一共设定了9个标志位,其中6个标志位用于反映ALU前一次操作的结果状态(CF,PF,AF,ZF,SF,OF),另3个标志位用于控制CPU操作(DF,IF,TF)。
5.如果某微处理器有20条地址总线和16条数据总线:
(1)假定存储器地址空间与I/O地址空间是分开的,则存储器地址空间有多大?
(2)数据总线上传送的有符号整数的范围有多大?
解:
(1)存储器地址空间为:
(2)有符号数范围为:
,即-32768~32767
6.将十六进制数62A0H与下列各数相加,求出其结果及标志位CF、AF、SF、ZF、OF和PF的值:
(1)1234H;
(2)4321H;(3)CFA0H;(4)9D60H
解:
(1)74D4HCF=0AF=0SF=0ZF=0OF=0PF=1
(2)A5C1HCF=0AF=0SF=1ZF=0OF=1PF=0
(3)3240HCF=1AF=0SF=0ZF=0OF=0PF=0
(4)0000HCF=1AF=0SF=0ZF=1OF=0PF=1
7.从下列各数中减去4AE0H,求出其结果及标志位CF、AF、SF、ZF、OF和PF的值:
(1)1234H;
(2)5D90H;(3)9090H;(4)EA04H
解:
(1)C754HCF=1AF=0SF=1ZF=0OF=0PF=0
(2)12B0HCF=0AF=0SF=0ZF=0OF=0PF=0
(3)45B0HCF=0AF=0SF=0ZF=0OF=1PF=0
(4)9F24HCF=0AF=0SF=1ZF=0OF=0PF=1
9.写出下列存储器地址的段地址、偏移地址和物理地址:
(1)2134:
10A0;
(2)1FA0:
0A1F;(3)267A:
B876
解:
物理地址=段地址*10H+偏移地址
(1)段地址:
2134H,偏移地址:
10A0H,物理地址:
223E0H
(2)段地址:
1FA0H,偏移地址:
0A1FH,物理地址:
2041FH
(3)段地址:
267AH,偏移地址:
B876H,物理地址:
32016H
10.给定一个数据的有效地址为2359H,并且(DS)=490BH,求该数据的物理地址。
解:
物理地址=段地址*10H+偏移地址
物理地址=490BH+2359H=4B409H
11.如果在一个程序段开始执行之前,(CS)=0A7F0H,(IP)=2B40H,求该程序段的第一个字的物理地址。
解:
物理地址=段地址*10H+偏移地址
物理地址=CS*10H+IP=AAA40H
12.IBMPC有哪些寄存器可用来指示存储器的地址?
解:
变址寄存器SI,DI,堆栈指针SP,BP,另外还有BX。
第3章8086CPU指令系统
1.写出完成下列要求的变量定义语句:
(1)在变量var1中保存6个字变量:
4512H,4512,-1,100/3,10H,65530;
(2)在变量var2中保存字符串:
’BYTE’,’word’,’WORD’;
(3)在缓冲区buf1中留出100个字节的存储空间;
(4)在缓冲区buf2中,保存5个字节的55H,再保存10个字节的240,并将这一过程重复7次;
(5)在变量var3中保存缓冲区buf1的长度;
(6)在变量pointer中保存变量var1和缓冲区buf1的偏移地址。
解:
var1DW4512H,4512,-1,100/3,10H,65530
var2DB’BYTE’,’word’,’WORD’
buf1DB100DUP(?
)
buf2DB7DUP(5DUP(55H),10DUP(240))
var3DBLENGTHbuf1
pointerDWvar1,buf1(或者pointerDWOFFSETvar1,OFFSETbuf1)
2.设变量var1的逻辑地址为0100:
0000,画出下列语句定义的变量的存储分配图:
var1DB12,-12,20/6,4DUP(0,55H)
var2DB‘Assemble’
var3DW‘AB’,‘cd’,‘E’
var4DWvar2
var5DDvar2
解:
3.指令正误判断,对正确指令写出源和目的操作数的寻址方式,对错误指令指出原因(设VAR1,VAR2为字变量,L1为标号):
(1)MOVSI,100
(2)MOVBX,VAR1[SI]
(3)MOVAX,[BX](4)MOVAL,[DX]
(5)MOVBP,AL(6)MOVVAR1,VAR2
(7)MOVCS,AX(8)MOVDS,0100H
(9)MOV[BX][SI],1(10)MOVAX,VAR1+VAR2
(11)ADDAX,LENGTHVAR1(12)ORBL,TYPEVAR2
(13)SUB[DI],78H(14)MOVSVAR1,VAR2
(15)PUSH100H(16)POPCS
(17)XCHGAX,ES(18)MOVDS,CS
(19)JMPL1+5(20)DIVAX,10
(21)SHLBL,2(22)MOVAL,15+23
(23)MULCX(24)XCHGCL,[SI]
(25)ADCCS:
[0100],AH(26)SBBVAR1-5,154
解:
(1)MOVSI,100正确。
源:
立即数寻址,目的:
寄存器寻址
(2)MOVBX,VAR1[SI]正确。
源:
寄存器相对寻址,目的:
寄存器寻址
(3)MOVAX,[BX]正确。
源:
寄存器间接寻址,目的:
寄存器寻址
(4)MOVAL,[DX]错误。
寄存器间接寻址时,DX,AX,CX不能作地址寄存器
(5)MOVBP,AL错误。
操作数类型不一致
(6)MOVVAR1,VAR2错误。
两存储单元之间不能用MOV指令传送数据
(7)MOVCS,AX错误。
CS不能为目的操作数
(8)MOVDS,0100H错误。
目的操作数为段寄存器时,源操作数不能为立即数
(9)MOV[BX][SI],1错误。
指令类型不定。
(10)MOVAX,VAR1+VAR2错误。
MOV指令中不能完成加法运算
(11)ADDAX,LENGTHVAR1正确。
源:
立即数寻址。
目的:
寄存器寻址
(12)ORBL,TYPEVAR2正确。
源:
立即数寻址。
目的:
寄存器寻址
(13)SUB[DI],78H错误。
指令类型不定
(14)MOVSVAR1,VAR2正确。
目的、源均为隐含寻址。
操作数仅指出操作数类型
(15)PUSH100H错误。
将常数压入堆栈,要通过寄存器来实现
(16)POPCS错误。
目的操作数不能为CS
(17)XCHGAX,ES错误。
XCHG指令的操作数不能是段寄存器
(18)MOVDS,CS错误。
MOV指令不能从段寄存器到段寄存器
(19)JMPL1+5正确。
段内直接转移
(20)DIVAX,10错误。
指令格式错误。
(21)SHLBL,2错误。
移位指令的移位数为1或者CL
(22)MOVAL,15+23正确。
源:
立即数寻址,目的:
寄存器。
编译时就处理为38
(23)MULCX正确。
源:
寄存器寻址,目的:
寄存器寻址
(24)XCHGCL,[SI]正确。
源:
寄存器间接寻址,目的:
寄存器寻址
(25)ADCCS:
[0100],AH正确。
源:
寄存器寻址,目的:
直接寻址(数据在代码段中)
(26)SBBVAR1-5,154正确。
源:
立即数寻址,目的:
直接寻址。
4.说明下列指令对的区别:
(1)MOVAX,VAR1与MOVAX,OFFSETVAR1
(2)MOVAX,VAR2与LEAAX,VAR2
(3)MOVAL,LENGTHVAR1与MOVAL,SIZEVAR1
(4)MOVAL,ES:
[DI]CMPAL,[SI]与CMPSB
(5)SHRAL,1与SARAL,1
(6)SHRAL,1与RORAL,1
(7)ROLBX,1与RCLBX,1
解:
(1)MOVAX,VAR1把变量VAR1对应地址单元中的一个字送入AX
MOVAX,OFFSETVAR1把VAR1的有效地址的偏移地址送入AX
(2)MOVAX,VAR2把变量VAR2对应地址单元中的一个字送入AX
LEAAX,VAR2把VAR2的有效地址的偏移地址送入AX
(3)MOVAL,LENGTHVAR1把变量VAR1的长度送入AL
MOVAL,SIZEVAR1把变量VAR1的大小送入AL
(4)MOVAL,ES:
[DI]
CMPAL,[SI]把以ES为段地址,DI为偏移地址的一个字节送入AL,
并与以SI内容为偏移地址的一个字节作比较,改变标志寄
存器内容。
(相当于作ES:
(DI)与(DS:
(SI)内容比较)
CMPSB对字符串中的一字节比较。
寻址方式隐含。
源串的地址由
DS:
SI指定,目的串的地址由ES:
DI指定。
(相当于作
DS:
(SI)与ES:
(DI)内容比较)
(5)SHRAL,1AL逻辑右移1位,最高位移入0,最低位移入CF。
SARAL,1AL算术右移1位,以最高位内容移入,最低位移入CF,其余各位
右移一位。
(6)SHRAL,1AL逻辑右移1位,最高位移入0,最低位移入CF。
RORAL,1AL的各位构成环形移位,右移一位,最低位内容同时移入到CF和
最高位。
(7)ROLBX,1BX各位构成环形移位,左移一位,最高位内容同时移入到CF和
最低位。
RCLBX,1BX和CF构成环形移位,左移一位,CF内容移入到最低位,最
高位移入CF。
5.写出下列转移指令的寻址方式(设L1为标号,VAR1为字型变量,DVAR1为双字型变量):
(1)JMPL1
(2)JMPNEARL1
(3)JNZL1(4)JMPBX
(5)JGL1(6)JMPVAR1[SI]
(7)JMPFARPTRL1(8)JMPDVAR1
解:
(1)JMPL1段内直接寻址
(2)JMPNEARPTRL1段内直接寻址
(3)JNZL1段内直接寻址(4)JMPBX段内间接寻址
(5)JGL1段内直接寻址(6)JMPVAR1[SI]段内间接寻址
(7)JMPFARPTRL1段间直接寻址(8)JMPDVAR1段间间接寻址
6.设(DS)=2000H,(BX)=0100H,(SI)=0002H,(20100)=3412H,(20102)=7856H,(21200)=4C2AH,(21202)=65
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 微机 原理 接口 技术 楼顺天版 课后 习题 答案 14