微机原理习题答案1234章解析.docx

上传人:b****1 文档编号:1661352 上传时间:2023-05-01 格式:DOCX 页数:100 大小:576.66KB
下载 相关 举报
微机原理习题答案1234章解析.docx_第1页
第1页 / 共100页
微机原理习题答案1234章解析.docx_第2页
第2页 / 共100页
微机原理习题答案1234章解析.docx_第3页
第3页 / 共100页
微机原理习题答案1234章解析.docx_第4页
第4页 / 共100页
微机原理习题答案1234章解析.docx_第5页
第5页 / 共100页
微机原理习题答案1234章解析.docx_第6页
第6页 / 共100页
微机原理习题答案1234章解析.docx_第7页
第7页 / 共100页
微机原理习题答案1234章解析.docx_第8页
第8页 / 共100页
微机原理习题答案1234章解析.docx_第9页
第9页 / 共100页
微机原理习题答案1234章解析.docx_第10页
第10页 / 共100页
微机原理习题答案1234章解析.docx_第11页
第11页 / 共100页
微机原理习题答案1234章解析.docx_第12页
第12页 / 共100页
微机原理习题答案1234章解析.docx_第13页
第13页 / 共100页
微机原理习题答案1234章解析.docx_第14页
第14页 / 共100页
微机原理习题答案1234章解析.docx_第15页
第15页 / 共100页
微机原理习题答案1234章解析.docx_第16页
第16页 / 共100页
微机原理习题答案1234章解析.docx_第17页
第17页 / 共100页
微机原理习题答案1234章解析.docx_第18页
第18页 / 共100页
微机原理习题答案1234章解析.docx_第19页
第19页 / 共100页
微机原理习题答案1234章解析.docx_第20页
第20页 / 共100页
亲,该文档总共100页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

微机原理习题答案1234章解析.docx

《微机原理习题答案1234章解析.docx》由会员分享,可在线阅读,更多相关《微机原理习题答案1234章解析.docx(100页珍藏版)》请在冰点文库上搜索。

微机原理习题答案1234章解析.docx

微机原理习题答案1234章解析

 

微机原理与接口技术

 

习题解答

 

第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)123456;(注:

表示回车)(3)ASCII;

(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)=65B7H,求下列指令执行后AX寄存器的内容:

(1)MOVAX,1200H;

(2)MOVAX,BX;(3)MOVAX,[1200H];

(4)MOVAX,[BX];(5)MOVAX,1100[BX];(6)MOVAX,[BX][SI];

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 解决方案 > 学习计划

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2