当前位置:文档之家› 哈尔滨工程大学微机原理课后题答案

哈尔滨工程大学微机原理课后题答案

哈尔滨工程大学微机原理课后题答案
哈尔滨工程大学微机原理课后题答案

第一章

1题

(1)110=6EH=01101110B (2)1039=40FH =010*********B

(3)0.75D=0.11B=0.CH (4)0.15625D=0.00101000B=0.28H

2题

(1)129 (0001 0010 1001)BCD

注:在计算机汇编程序中BCD码只能用16进制数表示,形式为129H

(2) 5678 (0101 0110 0111 1000) BCD

(3) 0.984 (0.1001 1000 0100) BCD

(4) 93.745 (1001 0011.011101000101) BCD

3题

(1) 10101010B=0AAH=170D (2)10000000B=80H=128D

(3) 11000011.01B=0C3.4H=195.25 (4) 01111110B=7EH=126D

4题

(1)8E6H=100011100110B=2278 (2)0A42H=101001000010B=2626

(3)7E.C5H=01111110.11000101B=126.769

(4)0F19.1DH=111100011001.00011101B=3865.11328

5题

(1)1011011.101B=91.625D BCD为(10010001.011000100101) BCD

(2)1010110.001B=86.125D BCD为(10000110.000100100101) BCD

6题

(0010 0111 0011) BCD 表示的十进制数为273 二进制数为100010001B

(1001 0111.0010 0101) BCD 表示的十进制数为97.25 二进制数为01100001.01B

7题

(1) (2) (3) (4)

1001.11B 1101.01B 1000.011B 1111B

+ 11.11B - 0110.11B - 1001.101B - 1101B

1101.10B 0110.10B 0110.110B 0010B

8题

6AH AB1 FH 12ADH 117H

+ A6H + 0 E FCH - 01DEH - 0ABH

110H B A 1B H 10C F H 06 CH

9题

(1)无符号数X=01H =01D Y=0FFH=255

(2)符号数X=01H =01D Y=0FFH= -1

注:对于同一个数到底是符号数还是无符号数是由程序设计者根据数据实际的意义决定的,一旦定下来,在程序中采用不同的指令来区分符号数和无符号数,即算数运算指令会有符号数和无符号两套指令。

10.题

(1)101+31H+69H+0D5H+(5*8+7)=531

(2)127.8125+189.625+253.9768+502.5390=1079.77344

11题

‘A’–‘Z ‘ASCII码为41H—5AH 48454C4C4FH

‘a’---‘z’ASCII码为61H---7AH (2) ‘A8’4138H

12题

(1) ‘E’ASCII码为45H 01001001B本身为奇数个1

所以偶校验D7为1,为0C5H;奇校验D7为0,为45H

(2) ‘6’ASCII码为36H 00110110B本身为偶数个1

所以偶校验D7为0,为36H;奇校验D7为1,为0B6H

13题

-38=[10100110B]原=[11011001B]反= [11011010B]补8位

-38=[1000000000100110B]原=[1111111111011001B]反= [1111111111011010B]补16位

125=[01111101B]原=[01111101B]反= [01111101B]补8位

125=[0000000001111101B]原=[0000000001111101B]反= [0000000001111101B]补16位

-128= [10000000B]补8位原码和反码不能用8位表示

-128=[1000000010000000B]原=[1111111101111111B]反= [1111111110000000B]补16位

14题

+0=[00000000B]原=[00000000B]反= [00000000B]补8位

高8位补0 为16位

-0=[10000000B]原=[11111111B]反= [00000000B]补8位

-0=[1000000000000000B]原=[1111111111111111B]反= [0000000000000000B]补16位

15题

(1)[X]补=81H =[111111111]原=[10000000]反真值为-127

(2)[X]补=800H=[1000100000000000B]原=[1111011111111111B]反真值为-211

(3)[X]补=79H=[01111001B]原=[01111001B]反真值为121

(4)[X]补=0FFFEH=[1000000000000010]原=[1111111111111101]反

16题

(1) [X]补=1000 0000 0000 0000B 真值为-8000H=-32768

(2) [X]补=1111 1111 1111 1111B 真值为-8000H=32768

(3) [X]补=0111 1111 1111 1111B 真值为7FFFH=32767

(4) [X]补=0101 0101 0101 0101B 真值为5555H=21845

17题

原码反码补码

(-1) (-127) (-1) (-127) (-1) (-128)

8位负数10000001B-11111111B 11111110B-1000000B 11111111B-1000000B (+1) (+127) (+1) (+127) (+1) (+127)

8位正数00000001B-01111111B 01111111B-00000000B 00000000B-01111111B [+0]原=000000000B [+0]反=00000000B [+0]补=00000000B

[-0]原=100000000B [-0]反=11111111B [-0]补=00000000B

N位的通式–(2N-1-1)---+(2N-1-1) –(2N-1-1)---+(2N-1-1) –(2N-1)---+(2N-1-1)

18题

(1) 不溢出结果为15未超出8位补码的范围

(2) 不溢出结果为-55未超出8位补码的范围

(3) 溢出结果为-132超出8位补码的范围

(4) 不溢出结果为-125未超出8位补码的范围

19题

(1) 27+11 (2) 37+29

00100111B 00110111B

+00010001B +00101001 B

00101000B 01100000B

+ 00000110B

01100110B

20题

(1)

17.5=00010001.1B 规范化表示0.100011× 25

浮点原码0 0101 0 100011B 反码和原码相同

(2)

-75.5=-01001011.1B 规范化表示-0.100101× 27(舍掉最低两位)

原码0 0111 1 100101 B 补码0 011 1 1 011011 B

第二章

1题省略

2题

总线:计算机系统各部分之间传递地址、数据和控制信息的共同线路的集合。

总线结构的好处:物理上是同时可以挂多个设备,但是总线上某一个时刻只有一个设备传送信息。

从空间上分为四类(是从PC机角度分类的)片内总线,片间总线(主总线,前端总线),系统总线(PCI ,ISA等标准总线),系统间通讯总线。

标准总线好处:总线接口标准统一便于通用。

总线传递信息分为三大类:数据总线,地址总线,控制总线。系统总线等也由是三大总线组成,只是根据不同的需要经过了变换。

3题

总线接口单元(BIU) :

1)形成访问内存或者I/O端口的物理地址;

2)从内存的代码段中取指令送到队列缓冲器中;

3)读取操作数参加EU运算或则存放运算结果到指定地址。

执行单元(EU)

1)从BIU的指令队列缓冲器中去指令进行译码、执行;

2)负责所有的算术,逻辑运算及16位偏移地址计算;

3)像BIU提供指令的执行结果和16位偏移地址。

二者同步进行操作,相当两级流水线,提高了效率。

4题省略

5题T1时刻是地址信息,用ALE信号锁存。注:凡是有ALE信号的CPU的某些管脚都具有分时复用的功能。(如51单片机,A VR单片机等)。T3时刻数据信息送出。通过地址锁存器保持地址信息。数据放大器(驱动器),加强总线的带载能力。

6题略

7题

7825H

+ 5A1FH

D244H CF=0; OF=1; ZF=0; PF=1; AF=1; SF=1;

7825H

-5A1FH

1E06H CF=0; OF=0; ZF=0; PF=1; AF=1; SF=0;

8 题

最大模式:除了8086/8088处理器外还有协处理器

最小模式:系统只有8086/8088处理器

9 题

访问存储器使用到哪些信号:WR RD M/IO ALE AD0-AD15 A16/S3-A19/S6等

10题

一个指令周期至少包含一个总线周期(即:取指令读存取器的所花的总线周期),一个总线周期包含4个时钟周,可会在T3后插入的等待周期。

11题省略

12题主要点为以下三点,有以下原因的前两点还会引申出来的其他区别,如执行指令的效率。但是二者的程序是完全兼容的。

8086 8088

外部总线16位外部总线8位

队列缓冲字节6个队列缓冲字节4个

M/IO IO/M

13题分时复用的信号,在总线周期前面出现的信号只要在后面的时钟周期还要维持其原来信号稳定不变就都要进行锁存。

14题指令队列缓冲区使得CPU可以取指和执行指令并行进行。8086复位后,CS=0FFFFH,其他寄存器为0,复位后程序指针指向了物理地址的FFFF0H的位置,一般在此处都是一条跳转指令,由此处跳到用户的自己的监控程序的入口处(开始的地方)。此特性具有通用性

15题

实际地址(物理地址)是20位的,而内部数据总线是16位的,只能通过段加偏移的办法段起始地址最低4位为0。

16题

地址线为N,则寻址存储单位(字节)多少的关系为:2N 。也可能为4位,16位等。

17题

逻辑地址表示为 段地址:偏移地址 ,是在编程时使用,计算机也是利用他们二者来找到实际地址的。

实际地址(物理地址)=段地址*16+偏移地址

段地址只是段起始地址(是一个段开始的物理地址,为20位)的高16位。

18 题 二者都是1117AH ,同一物理地址可以写成不同逻辑地址的形式,但在实际中一般不会出现。 19题

代码段的寻址就是通过 CS*16+IP ,所以指令存放的第一个字节单元的物理地址 A7B00H+2B50H=AA650H 20题

100字 200字节 200=C8H 偏移从2300H 开始,

2300H

23C7H

存储器

21题

字节数据 [123D4H]=78H [123D6H]=34H 字数据 [123D4H]=5678H [123D6H]=0E634H

22题

代码段

10000H

数据段

0FFFH 存储器

0000H

10FFFH 11000H

0000H

0000H 11800H

堆栈段

07FFH 117FFH 01FFH

119FFH

CS=1000H , DS=1100H ,SS=1180H

23题 偶地址开始存放的字数据为规则字,奇地址开始存放的字数据为非规则字。

第四章

4—1

(1)目的操作数:寄存器寻址,源操作数:立即寻址 (2)目的操作数:寄存器寻址,源操作数:直接寻址

(3)目的操作数:寄存器间接寻址,源操作数:寄存器寻址 (4)目的操作数:寄存器寻址,源操作数:相对基址变址寻址 (5)目的操作数:寄存器寻址,源操作数:基址变址寻址 (6)目的操作数:寄存器寻址,源操作数:寄存器寻址

(7)目的操作数:寄存器间接寻址 (SP 寄存器指向的内存单元),

源操作数:寄存器寻址

(8)目的操作数:寄存器寻址,源操作数:寄存器寻址 (9)目的操作数:寄存器寻址,源操作数:直接端口寻址 (10)目的操作数:间接端口寻址(端口的寄存器间接寻址),源操作数:寄存器寻址 (11)寄存器寻址

(12)目的操作数:相对寄存器寻址 4—2

(1)DI DS +?16 (2)SI BP SS ++?16 (3)1016++?BX DS

(4)H SI BX ES 1016+++? (5)H FF SI DS 8016++? (6)SP SS +?16

(7)H DS 202016+? (8)SI ES +?16 4—3

(1)类型不匹配(寄存器长度不一致) (2)CS 不能作目的操作数 (3)IP 不能作操作数

(4)立即数不能作目的操作数 (5)乘数不能是立即数

(6)两个存储器单元间不能用MOV 指令直接交换数据 (7)数据类型不确定(字节还是字操作不清楚)

(8)CUP 和I/O 间数据交换,只能用AX(AL)存放数据 (9)立即数不能直接赋值给段寄存器 (10)循环次数大于1放在CL 寄存器 (11)CX 不能作寄存器间接寻址的寄存器 (12)立即数不能做入栈操作 4—4

(1)AX=1200H (2)AX=647AH

(3)(10050H)=7DH,(10051H)=B7H, ZF=0,SF=1,CF=0,OF=0 (4)(12AD0H)=F7H,CF=0,OF=0

(5)(12BD0H)=31H,CH=31H

(6)BH=C9H,ZF=0,SF=1,CF=1.OF=0

(7)(12A80H)=2BH,(12A81H)=89H,CF=1

4—5

(1) LEA BX , BUF(或MOV BX ,OFFSET BUF)

ADD BX, 8

MOV CX , [BX]

(2) MOV BX ,OFFSET BUF(或LEA BX , BUF)

MOV CX , [BX+8]

MOV BX ,8

MOV CX , BUF [BX]

(3) MOV BX ,OFFSET BUF(或LEA BX , BUF)

MOV SI, 8

MOV CX , [BX+SI]

4—6

SP=100EH,AX=2468H,BX=2468H

4—7

(1)MOV AX , 0

(2)AND AX , 0

(3)XOR AX , AX

(4)SUB AX , AX

4—8 AX=0ABCH

AX=0ABBH

AX=0ABBH

CL=0004H

AX=ABB0H CL=0004H

CL=B0H

CL=28H

AX=ABB0H

AX=ABB0H

4—9 AL=FFH BL不变CF=0

4—10 AX=3520H

4—11 两条指令的区别是指令执行后是否保留运算结果,前条指令执行后AL的值改变后条指令中的AL的值不变。SF=1,CF=1,ZF=0,OF=0

4-12 以下程序中的WORD PTR都可以省略,因为变量的属性就是字。

(1)无符号数:

MOV AX , A

MUL WORD PTR C ; X*Y DX,AX ;

MOV CX , Z

MOV BX , 0 ;直接加0,拓展无符号数Z的高16位

SUB CX , AX

SBB BX , DX

MOV W , CX

MOV W+2 , BX

有符号数:

MOV AX , A

IMUL WORD PTR C ; X*Y→DX,AX ;

MOV CX , AX ;暂存X*Y→BX,CX ;

MOV BX , DX

MOV AX , Z ;16符号数Z符号位拓展,必须放在AX,拓展完放在DX,AX CWD

SUB AX , CX

SBB DX , BX

MOV W , AX

MOV W+2 , DX

(2) 无符号数:

MOV AX , D

ADD AX , B

MUL WORD PTR A

DIV WORD PTR C

MOV W , AX

MOV W+2 , DX

有符号数:

MOV AX , D

ADD AX , B

IMUL WORD PTR A

IDIV WORD PTR C

MOV W , AX

MOV W+2 , DX

(3)无符号数:

MOV AX , D

MOV DX , 0

DIV WORD PTR A

ADD AX , B

MOV W , AX

有符号数:

MOV AX , D

CWD

IDIV WORD PTR A

ADD AX , B

MOV W , AX

4-13 用指令TEST CX , 0400H 执行指令后,如果ZF=1,则D10为0,否则不为0

4-14 指令AND BYTE PTR [1000H] , 0

4-15 同时改变CS和IP 的有段间的跳转(直接和间接)、段间调用子程序以及段间中断服务程序,段内只改变IP。

4-16. 先行IP 为2102H (1)转移的目标地址IP=2102+0038H=213AH (2) 转移的目标地址IP=2102+FFD8H=213AH=20DAH 4-17. (1)L1 (2)L2 (3)L5 (4)L5 4-18 (1)CMP DX, CX JA L1

(2)CMP BX, AX JG L2

(3)CMP CX, 0 JE L3 (4)CMP BX, AX JO L4

(5)CMP BX, AX JLE L5

(6)CMP DX, CX JBE L6

4-19 (1) BE ,AE,LE,GE (2) A , AE, L,LE (3)L, LE,G, GE (4) B ,BE,G,GE

(5) B ,BE,L,LE (6) A, AE,G , GE

4-20 调用过程(子程序)时,断点要入栈,当调用子程序返回时,按照断点IP 开始执行程序。此处为段内跳转,所以只有IP 入栈。入栈的不是CALL 指令的IP ,而是它后面的指令的IP 地址,段内短跳转的CALL 指令为3字节,所以压栈的断点IP 地址为365BH

36

11FFH 1200H

堆栈

5B

11FEH SP

调用过程后

36

11FFH 1200H

堆栈

5B

11FEH 调用过程返

回后

第五章

第五章参考答案

5-1

(1) STAD DB 78,-40,0D6H,49H

(2)ARRAY DB 45H, 12H,64H,00H,0D2H,04H,0C7H,00H (3)ALPHA DB 12H,0FCH,0E4H,65H

(4)BETA DB 4 DUP(8),6 DUP(‘S ’),20 DUP( ‘ ’),10 DUP(1,3) (5)STRING DB ‘THIS IS A EXAMPE ’ (6) TOTAL EQU 780 TOTAL= 780 5-2

37

1D 29F6000C 3132000C 3132DATA2

DATA1

00

CD 00

123456DATA3

5-3

80...

0002000176

X1

X2

00

05000000

X3X2共42个元素(字变量)

COUNT 的值为42*2+4 表示变量X2和X3共占用的字节存储单元数 5-4

00

0501

0030

331E SA1

SA2

SA4

0100H

注:SA3不占用内存 5-5

00

30303000DA10030H

3000H 为字数据的偏移地址为0030H 5-6

(1) MOV BX ,OFFSET BUF1 或 LEA BX, BUF1 (2) MOV CL ,BYTE PTR BUF2+3 (3) MOV BUF3+7,0C6H (4)CNT EQU BUF4-BUF2 (5)MOV AL,BUF4+3 MOV AH,0

ADD AX,BUF2+1

MOV WORD PTR BUF3,AX

5-7

(1) 7CH (2)6752H (3)C0H (4)31H (5)04H 5-8

[DA2]=0D5B3H CF=0 5-9

第二个AND 为伪指令,在汇编时给出值。第一个AND 为指令,可改写成 AND AX,06H 5-10

DATA SEGMENT

BCD1 DB 31H,32H ; 十进制数1和2的ASCII BCD2 DB ? ;最终的结果应为21H DATA ENDS CODE SEGMENT

ASSUME CS:CODE, DS:DATA START: MOV AX,DATA MOV DS,AX MOV AL,BCD1 SUB AL,30H

MOV AH,AL;低4位暂存AH MOV AL,BCD1+1 SUB AL,30H MOV CL,4

SHL AL,CL ;高4位的左移4位

OR AL,AH

MOV BCD2,AL

MOV AH,4CH

INT 21H

CODE ENDS

END START

5-11

采用左移指令或者用:

MOV BX,AX MOV BX,AX

SHL BX,1 ;乘2 MOV CL,3

MOV DX,AX SHL AX, CL

MOV CL,2 SUB AX,BX

SHL AX ,CL ;乘4

ADD AX,BX ;3倍

ADD AX,DX ;7倍

5-12

3228H

5-13

(1) AL=00 (2)AL=01H (3)AL=FFH

5-14

编程思路有两种方法:1.将给出的BCD码首先转换成二进制数(十六进制数),按二进制的算术运算,将最终结果再转换为BCD码。2.按照BCD码进行运算,其中2*A按压缩BCD的加法(A+A)。

此题用方法2比较简单

DATA SEGMENT

BUFF DB 34H ; BCD码数据为十进制34

DES DB ? ;最终的结果应为21H

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE, DS:DATA

START: MOV AX, DATA

MOV DS, AX

MOV AL, BUFF

CMP AL,20H ; 十进制20H

JB ADDSELF

CMP AL, 60H

JB SUB20H

MOV DES, 80H

JMP NEXT

SUB20H: MOV AL,BUFF

SUB AL,20H

DAS

JMP OUTT

ADDSELF: MOV AL,BUFF

ADD AL,BUFF ;自加代替乘2 DAA

OUTT: MOV DES,AL NEXT:MOV AH,4CH INT 21H CODE ENDS

END START 5-15

数1=数2?

FLAG=2

数1=数3?

FLAG=1

数1=数3?

数2=数3?

FLAG=0OUTT

ALLEQU

TWOEQU

TEST1EQU3

TWOEQU

DATA SEGMENT

BUFER DW 1200H,1200H,1200H FLAG DB ? DATA ENDS

CODE SEGMENT

ASSUME CS:CODE ,DS: DATA START: MOV AX, DATA MOV DS, AX MOV AX,BUFER

CMP AX,BUFER+2 ;判断1和2是否相等 JZ TEST1EQU3

CMP AX,BUFER+4 ;判断1和3是否相等 JZ TWOEQU

MOV AX,BUFER+2 CMP AX,BUFER+4 JZ TWOEQU MOV FLAG , 0 JMP OUTT

TEST1EQU3:CMP AX,BUFER+4

JZ ALLEQU

TWOEQU: MOV FLAG,01H ;两个数相等

JMP OUTT

ALLEQU: MOV FLAG,02H ;三个数相等

OUTT: MOV AH, 4CH

INT 21H

CODE ENDS

END START

5-16

(1) AX=55H CX=0

(2) 5,6,7,8,9

5-17

DATTA SEGMENT

DATA DW 5, 7, 1900h, 2300h, 0a0h, 000BH, …,- 1

NUM EQU ($-BUF)/2

MAX DW ?

MIN DW ?

DATTA ENDS

CODE SEGMENT

ASSUME DS:DATTA, CS:CODE

START: MOV AX, DATTA

MOV DS, AX

MOV CX, NUM ;序列数据个数

MOV SI, 0

MOV DX, DATA ;大数存于DX中

MOV BX, DATA ;小数存于BX中

MOV CX, NUM-1

MOV SI, 2

LOP: CMP DX, DATA[SI]

JL BIG_CHG

CMP BX, DATA[SI]

JG LITTLE_CHG

JMP OUTT

BIG_CHG: MOV DX, DATA[SI]

JMP OUTT

LITTLE_CHG: MOV BX, DATA[SI]

OUTT: INC SI

INC SI

LOOP LOP

MOV MAX, DX

MOV MIN , BX

MOV AH, 4CH

INT 21H

CODE ENDS

END START

5-18

DATTA SEGMENT

NUMBER DB 5, 7, 19h, 23h, 0a0h, 0BH, …,- 1 CNT EQU $-BUF

PLUS DB CNT DUP(?)

DATTA ENDS

CODE SEGMENT

ASSUME DS:DATTA, CS:CODE START: MOV AX, DATTA

MOV DS, AX

MOV CX, CNT ;序列数据个数

MOV SI, OFFSET NUMBER

LEA DI, PLUS

LOP: MOV AL, [SI]

CMP AL ,0

JG PUT_PLUS

JMP OUTT

PUT_PLUS: MOV [DI],AL

INC DI

OUTT: INC SI

LOOP LOP

MOV AH, 4CH

INT 21H

CODE ENDS

END START

5-19

DA TA SEGMENT

MARK DB 98, 23, 90 ,77, 68 ,78 ,84 ,78, 79 ,98

COUNT EQU $-MARK

A_MARK DB 0 ;90分

B_MARK DB 0

C_MARK DB 0

D_MARK DB 0

E_MARK DB 0 ;不及格

A VERAGE D

B 0

DA TA ENDS

CODE SEGMENT

ASSUME CS:CODE ,DS: DA TA

START: MOV AX, DA TA

MOV DS, AX

MOV CX, COUNT

MOV SI, OFFSET MARK

XOR AX, AX ;成绩和清零

LOP: CMP BYTE PTR [SI], 60

JAE MARK_60

INC E_MARK ;低于60分

JMP OUTT

MARK_60: CMP BYTE PTR [SI], 70

JAE MARK_70

INC D_MARK ;低于70分

JMP OUTT

MARK_70: CMP BYTE PTR [SI], 80

JAE MARK_80

INC C_MARK

JMP OUTT

MARK_80: CMP BYTE PTR [SI], 90

JAE MARK_90

INC B_MARK

JMP OUTT

MARK_90: INC A_MARK

OUTT: ADD AL, [SI]

ADC AH, 0

INC SI

LOOP LOP

MOV BL, COUNT

DIV BL ;求平均值

MOV A VERAGE, AL

MOV AH, 4CH

INT 21H

CODE ENDS

END START

5-20

;;;1)通过INT21的01H功能输入一个字符,大小写的ASCII码相差20H ;;;2)显示过程中注意回车换行,或者采用空格,否则后出现在屏幕的字符会覆盖前面的字符

DA TA SEGMENT

STRING DB ?

DA TA ENDS

CODE SEGMENT

ASSUME CS:CODE ,DS: DA TA

START: MOV AX, DA TA

MOV DS, AX

LOP: MOV AH,01H

INT 21H ;输入字符并回显在屏幕

JZ OUTT ;为结束符退出循环

MOV STRING,AL ;将输入字符的ASCII码存入内存单元

MOV DL ,0DH ;显示回车字符

MOV AH ,02H

INT 21H

MOV DL ,0AH ;显示换行字符

MOV AH ,02H

INT 21H

MOV AL ,STRING

SUB AL,20H ;输入字符为小写,减20H为大写

MOV DL ,AL

MOV AH ,02H

INT 21H

MOV DL ,0DH ;显示回车字符

MOV AH ,02H

INT 21H

MOV DL ,0AH ;显示换行字符

MOV AH ,02H

INT 21H

JMP LOP ;死循环

OUTT: MOV AH, 4CH

INT 21H

CODE ENDS

END START

5-21

DA TA SEGMENT

PKK DB 'adgdggdaad#ghg#uioo'

CNT EQU $-PKK ;题目要求是100个字符,此处自己定义非100,

CUT DB ?

NUM_OFFSET DW 0 ;存放和PKK的距离,100个字符,实际字节数据就可以表示距离值DA TA ENDS

CODE SEGMENT

ASSUME CS: CODE ,DS: DATA

START: MOV AX, DA TA

MOV DS, AX

MOV CX,CNT

MOV CUT,0

MOV BX,0 ;采用相对寄存器间接寻址

AGAIN: CMP PKK[BX] ,'#'

JNZ NEXT

INC CUT

MOV NUM_OFFSET,BX ;和首个字符的距离值

NEXT: INC BX

OUTT: MOV AH, 4CH

INT 21H

CODE ENDS

END START

5-22

;;;程序中没有考虑大小写混合的情况,只考虑单一情况

;;;排序采用冒泡法,具体思路参考教材上的191-193页

DA TA SEGMENT

STRING DB 'DKSNTEYERTY',0DH,0AH,'$'; 0DH为回车字符,0AH为换行字符,

; ' $'显示到此结束

CNT EQU $-STRING-3 ;去掉最后三个字符

CHAGE_STRING DB CNT DUP(?)

DA TA ENDS

CODE SEGMENT

ASSUME CS:CODE ,DS: DA TA

START: MOV AX, DA TA

MOV DS, AX

LEA DX,STRING

MOV AH,09H

INT 21H

MOV DX,CNT-1

LOP: MOV CX,DX

MOV SI,0

MOV AH,0

AGAIN: MOV AL ,STRING[SI]

CMP AL,STRING[SI+1]

JLE NEXT

XCHG AL ,STRING[SI+1]

XCHG AL,STRING[SI]

MOV AH,01H

NEXT: INC SI

LOOP AGAIN

DEC DX

OR AH ,AH

JNZ LOP

LEA DX,STRING

MOV AH,09H

微机原理考试课后练习题筛选

第一章 一、选择题 7.(D)8.(B)9.(D)10.(C)11.(A) 二、填空题 l.(运算器)2.(冯·诺依曼、输出器、存储器、存储器)9.(尾数、指数) 第二章 一、选择题 1.(C)4.(B)5.(D)7.(A)8.(D)18.(B) 二、填空题 4.(TF、DF、IF) 5. (9E100H)10.(0、0、 1、1)15.(FFFFH、0000H、0000H、0000H) 三、问答题 2.完成下列补码运算,并根据结果设置标志SF、ZF、CF和OF,指出运算结果是否溢出? (1)00101101B+10011100B (2) 01011101B-10111010B (3)876AH-0F32BH (4)10000000B十 11111111B (1)00101101B +10011100B 11001001B=C9H SF=1 ZF=0 CF=0 OF=0 (2) -10111010B=01000110B 01011101B-10111010B=01011101B +01000110B 10100011B SF=1 ZF=0 CF=0 OF=1 (3)876AH-0F32BH=876AH +0CD5H 943FH SF=1 ZF=0 CF=0 OF=0 (4) 10000000B +11111111B 101111111B=7FH SF=0 ZF=0 CF=1 OF=1 习题3 一、选择题 1.D 4.B 5.A 14.D 17.C 二、填空题 7. 3400H;5000H 8. 9AH;6CH;0;1;1;1;0 17.低8位;高8位;0FFA4H 三,问答题 1、(1)源操作数是基址寻址,目的操作数是寄存器寻址(2)逻辑地址是0705H,物理地址是10705H (3)(AX)=1234H (BX)=0700H 10、(1)MOV SI,2500H MOV DI,1400H MOV CX,64H CLD REP MOVSB (2) MOV SI,2500H MOV DI,1400H MOV CX,64H CLD REPE CMPSB JNZ L1 XOR BX,BX HLT L1:DEC SI MOV BX,SI MOV AL,[SI] HLT 习题4 一、选择题 1.B 4.C 二、填空题 1..ASM;.OBJ;.EXE 6.( AX)= 1 (BX)= 2 (CX)= 20 (DX)= 40

(完整版)微机原理课后习题参考答案

第一章 2、完成下列数制之间的转换。 (1)01011100B=92D (3)135D=10000111B (5)10110010B=262Q=B2H 3、组合型BCD码和非组合型BCD码有什么区别?写出十进制数254的组合型BCD数和非组合型数。 答:组合型BCD码用高四位和低四位分别对应十进制数的个位和十位,其表示范围是0~99;非组合型BCD码用一个字节的低四位表示十进制数,高四位则任意取值,表示范围为0~9。 组合型:254=(001001010100)BCD 非组合型:254=(00000010 00000101 00000100)BCD 7、计算机为什么采用补码形式存储数据?当计算机的字长n=16,补码的数据表示范围是多少? 答:在补码运算过程中,符号位参加运算,简化了加减法规则,且能使减法运算转化为加法运算,可以简化机器的运算器电路。+32767~ -32768。 9、设计算机字长n=8,求下列各式的[X+Y]补和[X-Y]补,并验证计算结果是否正确。 (1)X=18,Y=89 [X+Y]补=00010010+01011001=01101011B=107D 正确 [X-Y]补=10111001B=00010010+10100111=(-71D)补正确 (2)X=-23,Y=-11 [X+Y]补=11101001+11110101=11011110B=(-34D)补正确[X-Y]补=11101001+00001011=11110100B=(-12D)补正确 (3)X=18,Y=-15 [X+Y]补=00010010+11110001=00000011B=(3D)补正确 [X-Y]补=00010010+00001111=00100001B=(33D)补正确 (4)X=-18,Y=120 [X+Y]补=11101110+01111000=01100110B=(102D)补正确[X-Y]补=11101110+10001000=01110110B=(123D)补由于X-Y=-138 超出了机器数范围,因此出错了。 13、微型计算机的主要性能指标有哪些? 答:CPU字长、存储器容量、运算速度、CPU内核和IO工作电压、制造工艺、扩展能力、软件配置。 第二章 2、8086标志寄存器包含哪些标志位?试说明各标志位的作用。 答:进位标志:CF;奇偶校验:PF;辅助进位:AF;零标志:ZF;符号标志:SF;溢出标志:OF。 5、逻辑地址与物理地址有什么区别?如何将逻辑地址转换为物理地址? 答:物理地址是访问存储器的实际地址,一个存储单元对应唯一的一个物理地址。逻辑地址是对应逻辑段内的一种地址表示形式,它由段基址和段内偏移地址两部分组成,通常表示为段基址:偏移地址。 物理地址=段基址*10H+偏移地址。 6、写出下列逻辑地址的段基址、偏移地址和物理地址。 (1)2314H:0035H (2)1FD0H:000AH 答:(1)段基址:2314H;偏移地址:0035H;物理地址:23175H。 (2)段基址:1FD0H;偏移地址:000AH;物理地址:1FD0AH。 8、设(CS)=2025H,(IP)=0100H,则当前将要执行指令的物理地址是多少? 答:物理地址=(CS)*10H+(IP)=20350H 9、设一个16字的数据区,它的起始地址为70A0H:DDF6H(段基址:偏移地址),求这个数据区的首字单元和末字单元的物理地址。

微机原理课后练习题-答案

1、 2、B 3、十,非压缩的BCD码 4、 5、微型计算机、微型计算机系统 6、,, 二、 B D B 三、 1、微型计算机系统的基本组成。 答案:以微型计算机为主体,配上相应的系统软件、应用软件和外部设备之后,组成微型计算机系统。 2、简述冯.诺依曼型计算机基本组成。 答案:冯.诺依曼型计算机是由运算器,控制器,存储器,输入设备和输出设备组成的。其中,运算器是对信息进行加工和运算的部件;控制器是整个计算机的控制中心,所以数值计算和信息的输入,输出都有是在控制器的统一指挥下进行的;存储器是用来存放数据和程序的部件,它由许多存储单元组成,每一个存储单元可以存放一个字节;输入设备是把人们编写好的程序和数据送入到计算机内部;输出设备是把运算结果告知用户。 3、什么是微型计算机 答案:微型计算机由CPU、存储器、输入/输出接口电路和系统总线构成。 4、什么是溢出 答案:在两个有符号数进行家减运算时,如果运算结果超出了该符号数可表示的范围,就会发生溢出,使计算出错。

1、4、100ns 2、Ready ,Tw(等待) 3、ALE 4、INTR 5、85010H 6、存储器或I/O接口未准备好 7、非屏蔽中断 8、指令周期 9、4 二、 1、在内部结构上,微处理器主要有那些功能部件组成 答案:1) 算术逻辑部件2) 累加器和通用寄存器组 3) 程序计数器4) 时序和控制部件 2、微处理器一般应具有那些基本功能 答案:1.可以进行算术和逻辑运算2.可保存少量数据 3.能对指令进行译码并完成规定的操作4.能和存储器、外部设备交换数据 5.提供整个系统所需的定时和控制6.可以响应其他部件发来的中断请求 3、什么是总线周期 答案:CPU通过外部总线对存储器或I/O端口进行一次读/写操作的过程;一个基本的总线周期包含4个T状态,分别称为T1、T2、T3、T4。 三、×、×、×、×、×、√、√

微机原理课后习题答案

李伯成《微机原理》习题第一章 本章作业参考书目: ①薛钧义主编《微型计算机原理与应用——Intel 80X86系列》 机械工业出版社2002年2月第一版 ②陆一倩编《微型计算机原理及其应用(十六位微型机)》 哈尔滨工业大学出版社1994年8月第四版 ③王永山等编《微型计算机原理与应用》 西安电子科技大学出版社2000年9月 1.1将下列二进制数转换成十进制数: X=10010110B= 1*27+0*26+0*25+1*24+0*23+1*22+1*21 +0*21 =128D+0D+0D+16D+0D+0D+4D+2D=150D X=101101100B =1*28+0*27+1*26+1*25+0*24+1*23+1*22+0*21+0*20 =256D+0D+64D+32D+0D+16D+4D+0D=364D X=1101101B= 1*26+1*25+0*24+1*23+1*22+0*21 +1*20 =64D+32D+0D+8D+4D+0D+1D=109D 1.2 将下列二进制小数转换成十进制数: (1)X=0.00111B= 0*2-1+0*2-2+1*2-3+1*2-4+1*2-5= 0D+0D+0.125D+0.0625D+0.03125D=0.21875D (2) X=0.11011B= 1*2-1+1*2-2+0*2-3+1*2-4+1*2-5= 0.5D+0.25D+0D+0.0625D+0.03125D=0.84375D (3) X=0.101101B= 1*2-1+0*2-2+1*2-3+1*2-4+0*2-5+1*2-6= 0.5D+0D+0.125D+0.0625D+0D+0.015625D=0.703125D 1.3 将下列十进制整数转换成二进制数: (1)X=254D=11111110B (2)X=1039D=10000001111B (3)X=141D=10001101B 1.4 将下列十进制小数转换成二进制数: (1)X=0.75D=0.11B (2) X=0.102 D=0.0001101B (3) X=0.6667D=0.101010101B 1.5 将下列十进制数转换成二进制数 (1) 100.25D= 0110 0100.01H (2) 680.75D= 0010 1010 1000.11B 1.6 将下列二进制数转换成十进制数 (1) X=1001101.1011B =77.6875D

微机原理及接口技术课后习题及参考答案

第一章课后习题 1.1 把下列十进制数转换成二进制数、八进制数、十六进制数。 ① 16.25 ② 35.75 ③ 123.875 ④ 97/128 1.2 把下列二进制数转换成十进制数。 ① 10101.01 ② 11001.0011 ③ 111.01 ④ 1010.1 1.3 把下列八进制数转换成十进制数和二进制数。 ① 756.07 ② 63.73 ③ 35.6 ④ 323.45 1.4 把下列十六进制数转换成十进制数。 ① A7.8 ② 9AD.BD ③ B7C.8D ④ 1EC 1.5 求下列带符号十进制数的8位补码。 ① +127 ② -1 ③ -0 ④ -128 1.6 求下列带符号十进制数的16位补码。 ① +355 ② -1 1.7 计算机分那几类?各有什么特点? 1.8 简述微处理器、微计算机及微计算机系统三个术语的内涵。 1.9 80X86微处理器有几代?各代的名称是什么? 1.10 你知道现在的微型机可以配备哪些外部设备? 1.11 微型机的运算速度与CPU的工作频率有关吗? 1.12 字长与计算机的什么性能有关? 习题一参考答案 1.1 ① 16.25D=10000.01B=20.2Q=10.4H ② 35.75D=100011.11B=43.6Q=23.CH ③ 123.875D=1111011.111B=173.7Q=7B.EH ④ 97/128D=64/123+32/128+1/128=0.1100001B=0.604Q=0.C2H 1.2 ① 10101.01B=21.25D ② 11001.0011B=25.1875D ③ 111.01B=7.25D ④ 1010.1B=10.5D 1.3 ① 756.07Q=111101110.000111B=494.109D ② 63.73Q=110011.111011B=51.922D ③ 35.6Q=11101.110B=29.75D ④ 323.45Q=11010011.100101B=211.578D 1.4 ① A7.8H=167.5D ② 9AD.BDH=2477.738D ③ B7C.8D=2940.551D ④ 1ECH=492D 1.5 ① [+127] 补=01111111 ② [-1] 补 = 11111111 ③ [-0] 补=00000000 ④[-128] 补 =10000000 1.6 ① [+355] 补= 0000000101100011 ② [-1] 补 = 1111 1111 1111 1111 1.7 答:传统上分为三类:大型主机、小型机、微型机。大型主机一般为高性能的并行处理系统,存储容量大,事物处理能力强,可为众多用户提供服务。小型机具有一定的数据处理能力,提供一定用户规模的信息服务,作为部门的信息服务中心。微型机一般指在办公室或家庭的桌面或可移动的计算系统,体积小、价格低、具有工业化标准体系结构,兼容性好。 1.8 答:微处理器是微计算机系统的核心硬件部件,对系统的性能起决定性的影

微机原理课后作业答案第五版

第一章 6、[+42]原=00101010B=[+42]反=[+42]补 [-42]原 [-42]反 [-42]补 [+85]原=01010101B=[+85]反=[+85]补 [-85]原 [-85]反 [-85]补 10、微型计算机基本结构框图 微处理器通过一组总线(Bus)与存储器和I/O接口相连,根据指令的控制,选中并控制它们。微处理器的工作:控制它与存储器或I/O设备间的数据交换;进行算术和逻辑运算等操作;判定和控制程序流向。 存储器用来存放数据和指令,其内容以二进制表示。每个单元可存8位(1字节)二进制信息。 输入——将原始数据和程序传送到计算机。 输出——将计算机处理好的数据以各种形式(数字、字母、文字、图形、图像和声音等)送到外部。 接口电路是主机和外设间的桥梁,提供数据缓冲驱动、信号电平转换、信息转换、地址译码、定时控制等各种功能。 总线:从CPU和各I/O接口芯片的内部各功能电路的连接,到计算机系统内部的各部件间的数据传送和通信,乃至计算机主板与适配器卡的连接,以及计算机与外部设备间的连接,都要通过总线(Bus)来实现。 13、8086有20根地址线A19~A0,最大可寻址220=1048576字节单元,即1MB;80386有32根地址线,可寻址232=4GB。8086有16根数据线,80386有32根数据线。

1、8086外部有16根数据总线,可并行传送16位数据; 具有20根地址总线,能直接寻址220=1MB的内存空间; 用低16位地址线访问I/O端口,可访问216=64K个I/O端口。 另外,8088只有8根数据总线 2、8086 CPU由两部分组成:总线接口单元(Bus Interface Unit,BIU) BIU负责CPU与内存和I/O端口间的数据交换: BIU先从指定内存单元中取出指令,送到指令队列中排队,等待执行。 执行指令时所需的操作数,也可由BIU从指定的内存单元或I/O端口中获取,再送到EU去执行。 执行完指令后,可通过BIU将数据传送到内存或I/O端口中。 指令执行单元(Execution Unit,EU) EU负责执行指令: 它先从BIU的指令队列中取出指令,送到EU控制器,经译码分析后执行指令。EU的算术逻辑单元(Arithmetic Logic Unit,ALU)完成各种运算。 6、见书P28-29。 7.(1) 1200:3500H=1200H×16+3500H=15500H (2) FF00:0458H=FF00H×16+0458H=FF458H (3) 3A60:0100H=3A80H×16+0100H=3A700H 8、(1)段起始地址 1200H×16=12000H,结束地址 1200H×16+FFFFH=21FFFH (2)段起始地址 3F05H×16=3F050H,结束地址 3F05H×16+FFFFH=4F04FH (3)段起始地址 0FFEH×16=0FFE0H,结束地址 0FFEH×16+FFFFH=1FFD0H 9、3456H×16+0210H=34770H 11、堆栈地址范围:2000:0000H~2000H(0300H-1),即20000H~202FFH。执行 两条PUSH指令后,SS:SP=2000:02FCH,再执行1条PUSH指令后,SS: SP=2000:02FAH。 12、(2000H)=3AH, (2001H)=28H, (2002H)=56H, (2003H)=4FH 从2000H单元取出一个字数据需要1次操作,数据是 283AH; 从2001H单元取出一个字数据需要2次操作,数据是 5628H; 17、CPU读写一次存储器或I/O端口的时间叫总线周期。1个总线周期需要4个系统时钟周期(T1~T4)。8086-2的时钟频率为8MHz,则一个T周期为125ns,一个总线周期为500ns,则CPU每秒最多可以执行200万条指令。

微机原理与接口技术课后习题答案

第1章微型计算机系统 〔习题〕简答题 (2)总线信号分成哪三组信号 (3)PC机主存采用DRAM组成还是SRAM组成 (5)ROM-BIOS是什么 (6)中断是什么 (9)处理器的“取指-译码-执行周期”是指什么 〔解答〕 ②总线信号分成三组,分别是数据总线、地址总线和控制总线。 ③ PC机主存采用DRAM组成。 ⑤ ROM-BIOS是“基本输入输出系统”,操作系统通过对BIOS 的调用驱动各硬件设备,用户也可以在应用程序中调用BIOS中的许多功能。 ⑥中断是CPU正常执行程序的流程被某种原因打断、并暂时停止,转向执行事先安排好的一段处理程序,待该处理程序结束后仍

返回被中断的指令继续执行的过程。 ⑨指令的处理过程。处理器的“取指—译码—执行周期”是指处理器从主存储器读取指令(简称取指),翻译指令代码的功能(简称译码),然后执行指令所规定的操作(简称执行)的过程。 〔习题〕填空题 (2)Intel 8086支持___________容量主存空间,80486支持___________容量主存空间。 (3)二进制16位共有___________个编码组合,如果一位对应处理器一个地址信号,16位地址信号共能寻址___________容量主存空间。 (9)最初由公司采用Intel 8088处理器和()操作系统推出PC机。 ② 1MB,4GB ③ 216,64KB (9)IBM,DOS 〔习题〕说明微型计算机系统的硬件组成及各部分作用。 〔解答〕

CPU:CPU也称处理器,是微机的核心。它采用大规模集成电路芯片,芯片内集成了控制器、运算器和若干高速存储单元(即寄存器)。处理器及其支持电路构成了微机系统的控制中心,对系统的各个部件进行统一的协调和控制。 存储器:存储器是存放程序和数据的部件。 外部设备:外部设备是指可与微机进行交互的输入(Input)设备和输出(Output)设备,也称I/O设备。I/O设备通过I/O接口与主机连接。 总线:互连各个部件的共用通道,主要含数据总线、地址总线和控制总线信号。 〔习题〕区别如下概念:助记符、汇编语言、汇编语言程序和汇编程序。 〔解答〕 助记符:人们采用便于记忆、并能描述指令功能的符号来表示机器指令操作码,该符号称为指令助记符。 汇编语言:用助记符表示的指令以及使用它们编写程序的规则就形成汇编语言。 汇编语言程序:用汇编语言书写的程序就是汇编语言程序,或称汇编语言源程序。

微机原理课后作业答案(第五版)

6、[+42]原=00101010B=[+42]反=[+42]补 [-42]原=B [-42]反=B [-42]补=B [+85]原=01010101B=[+85]反=[+85]补 [-85]原=B [-85]反=B [-85]补=B 10、微型计算机基本结构框图 微处理器通过一组总线(Bus)与存储器和I/O接口相连,根据指令的控制,选中并控制它们。微处理器的工作:控制它与存储器或I/O设备间的数据交换;进行算术和逻辑运算等操作;判定和控制程序流向。 存储器用来存放数据和指令,其内容以二进制表示。每个单元可存8位(1字节)二进制信息。 输入——将原始数据和程序传送到计算机。 输出——将计算机处理好的数据以各种形式(数字、字母、文字、图形、图像和声音等)送到外部。 接口电路是主机和外设间的桥梁,提供数据缓冲驱动、信号电平转换、信息转换、地址译码、定时控制等各种功能。 总线:从CPU和各I/O接口芯片的内部各功能电路的连接,到计算机系统内部的各部件间的数据传送和通信,乃至计算机主板与适配器卡的连接,以及计算机与外部设备间的连接,都要通过总线(Bus)来实现。 13、8086有20根地址线A19~A0,最大可寻址220=1048576字节单元,即1MB;80386有32根地址线,可寻址232=4GB。8086有16根数据线,80386有32根数据线。

1、8086外部有16根数据总线,可并行传送16位数据; 具有20根地址总线,能直接寻址220=1MB的内存空间; 用低16位地址线访问I/O端口,可访问216=64K个I/O端口。 另外,8088只有8根数据总线 2、8086 CPU由两部分组成:总线接口单元(Bus Interface Unit,BIU) BIU负责CPU与内存和I/O端口间的数据交换: BIU先从指定内存单元中取出指令,送到指令队列中排队,等待执行。 执行指令时所需的操作数,也可由BIU从指定的内存单元或I/O端口中获取,再送到EU去执行。 执行完指令后,可通过BIU将数据传送到内存或I/O端口中。 指令执行单元(Execution Unit,EU) EU负责执行指令: 它先从BIU的指令队列中取出指令,送到EU控制器,经译码分析后执行指令。EU的算术逻辑单元(Arithmetic Logic Unit,ALU)完成各种运算。 6、见书P28-29。 7.(1)1200:3500H=1200H×16+3500H=15500H (2)FF00:0458H=FF00H×16+0458H=FF458H (3)3A60:0100H=3A80H×16+0100H=3A700H 8、(1)段起始地址1200H×16=12000H,结束地址1200H×16+FFFFH=21FFFH (2)段起始地址3F05H×16=3F050H,结束地址3F05H×16+FFFFH=4F04FH (3)段起始地址0FFEH×16=0FFE0H,结束地址0FFEH×16+FFFFH=1FFD0H 9、3456H×16+0210H=34770H 11、堆栈地址范围:2000:0000H~2000H(0300H-1),即20000H~202FFH。执行两条PUSH指令后,SS:SP=2000:02FCH,再执行1条PUSH指令后,SS:SP=2000:02FAH。 12、(2000H)=3AH, (2001H)=28H, (2002H)=56H, (2003H)=4FH 从2000H单元取出一个字数据需要1次操作,数据是283AH; 从2001H单元取出一个字数据需要2次操作,数据是5628H; 17、CPU读写一次存储器或I/O端口的时间叫总线周期。1个总线周期需要4个系统时钟周期(T1~T4)。8086-2的时钟频率为8MHz,则一个T周期为125ns,一个总线周期为500ns,则CPU每秒最多可以执行200万条指令。

微机原理课后答案

1.2 课后练习题 一、填空题 1.将二进制数1011011.1转换为十六进制数为__5B.8H_____。 2.将十进制数199转换为二进制数为____ 11000111____B。 3.BCD码表示的数,加减时逢__10____进一,ASCII码用来表示数值时,是一种非压缩的BCD 码。 4.十进制数36.875转换成二进制是___100100.111____________。 5.以_微型计算机____为主体,配上系统软件和外设之后,就构成了__微型计算机系统____。6.十进制数98.45转换成二进制为__1100010.0111_B、八进制__142.3463________Q、十六进制__62.7333________H。(精确到小数点后4位) 二、选择题 1.堆栈的工作方式是__B_________。 A)先进先出B)后进先出C)随机读写D)只能读出不能写入 2.八位定点补码整数的范围是____D_________。 A)-128-+128 B)-127-+127 C)-127-+128 D)-128-+127 3.字长为16位的数可表示有符号数的范围是___B___。 A)-32767-+32768 B)-32768-+32767 C)0-65535 D)-32768-+32768 三、简答题 1.微型计算机系统的基本组成? 微型计算机,系统软件,应用软件,输入输出设备 2.简述冯.诺依曼型计算机基本思想? ●将计算过程描述为由许多条指令按一定顺序组成的程序,并放入存储器保存 ●指令按其在存储器中存放的顺序执行; ●由控制器控制整个程序和数据的存取以及程序的执行; ●以运算器为核心,所有的执行都经过运算器。 3.什么是微型计算机? 微型计算机由CPU、存储器、输入/输出接口电路和系统总线构成。 4.什么是溢出? 运算结果超出了计算机所能表示的范围。 2.2 一、填空题 1. 8086/8088的基本总线周期由___4____个时钟周期组成,若CPU主频为10MHz,则一个时钟周期的时间为___0.1μs_____。 2. 在8086CPU的时序中,为满足慢速外围芯片的需要,CPU采样___READY_________信号,若未准备好,插入___TW__________时钟周期。 3. 8086系统总线形成时,须要用_____ALE__________信号锁定地址信号。 4. 对于8086微处理器,可屏蔽中断请求输入信号加在_____INTR__________引脚。

微机原理(第三版)课后练习答案

1 思考与练习题 一、选择题 1.计算机硬件中最核心的部件是( )。C A.运算器 B.主存储器 C.CPU D.输入/输出设备 2.微机的性能主要取决于( )。 A (B——计算机数据处理能力的一个重要指标) A.CPU B.主存储器 C.硬盘 D.显示器 3.计算机中带符号数的表示通常采用( )。C A.原码 B.反码 C.补码 D.BCD码 4.采用补码表示的8位二进制数真值范围是( )。C A.-127~+127 B.-1 27~+128 C.-128~+127 D.-128~+128 5.大写字母“B”的ASCII码是( )。B A.41H B.42H C.61H D.62H 6.某数在计算机中用压缩BCD码表示为10010011,其真值为( )。C A.10010011B B.93H C.93 D.147 二、填空题 1.微处理器是指_CPU_;微型计算机以_CPU_为核心,配置_内存和I/O接口_构成;其特点是_(1)功能强 (2)可靠性高 (3)价格低 (4)适应性强 (5)体积小 (6)维护方便_。P8 P5 2.主存容量是指_RAM和ROM总和_;它是衡量微型计算机_计算机数据处理_能力的一个重要指标;构成主存的器件通常采用_DRAM和PROM半导体器件_。P5 P9 3.系统总线是_CPU与其他部件之间传送数据、地址和控制信息_的公共通道;根据传送内容的不同可分成_数据、地址、控制_3种总线。P9 4.计算机中的数据可分为_数值型和非数值型_两类,前者的作用是_表示数值大小,进行算术运算等处理操作_;后者的作用是_表示字符编码,在计算机中描述某种特定的信息_。P12 5.机器数是指_数及其符号在机器中加以表示的数值化_;机器数的表示应考虑_机器数的范围、机器数的符号、机器数中小数点位置_3个因素。P15 P16 6.ASCII码可以表示_128_种字符,其中起控制作用的称为_功能码_;供书写程序和描述命令使用的称为_信息码_。P18 P19 三、判断题 1.计算机中带符号数采用补码表示的目的是为了简化机器数的运算。( )√ 2.计算机中数据的表示范围不受计算机字长的限制。( )× 3.计算机地址总线的宽度决定了内存容量的大小。( )√ 4.计算机键盘输入的各类符号在计算机内部均表示为ASCII码。( )× (键盘与计算机通信采用ASCII码) 2 思考与练习题 一、选择题 1.在EU中起数据加工与处理作用的功能部件是( )。A A.ALU B.数据暂存器 C.数据寄存器 D.EU控制电路 2.以下不属于BIU中的功能部件是( )。 B A.地址加法器 B.地址寄存器 C.段寄存器 D.指令队列缓冲器

微机原理(王忠民版课后答案)

部分习题答案 第二章计算机中的数值和编码 1、将十进制数转换为二进制和十六进制 (1) =1000 =(2) =1101 = (3) ==(4) =10 1B=H 2、将下列二进制数转换为十进制和十六进制 (1) 111010 B=58 =3A H(2) 1011 = =H (3) 1B= = (4) B= = 3、完成下列二进制数的加减法运算 (1) +=(2) -= (3) 00111101+=(4) -= 4、完成下列十六进制数的加减法运算 (1) 745CH+56DFH=D14B H(2) -=H (3) +=1678 .FC H(4) 6F01H-EFD8H=7F29 H 5、计算下列表达式的值 (1) +.1011B+= (2) -.11H+= (3) ++-= 6、选取字长n为8位和16位两种情况,求下列十进制数的补码。 (1) X=-33的补码:1101 1111, 111 (2) Y=+33的补码:0010 0001, 0000 0000 0010 0001 (3) Z=-128的补码:1000 0000,1111 1111 1000 0000 (4) N=+127的补码:0111 1111, 0000 0000 0111 1111 (5) A=-65的补码:1011 1111, 1111 1111 1011 1111 (6) B=+65的补码:0100 0001,0000 0000 0100 0001 (7) C=-96的补码:1010 0000,1111 1111 1010 0000 (8) D=+96的补码:0110 0000, 0000 0000 0110 0000 7、写出下列用补码表示的二进制数的真值 (1) [X]补=1000 0000 0000 0000 H X=-1000 0000 0000 0000 H=-32768 (2) [Y]补=0000 0001 0000 0001 H Y=+0000 0001 0000 0001 H=+257 (3) [Z]补=1111 1110 1010 0101 H Z=-0000 0001 0101 1011 H=-347 (4) [A]补=0000 0010 0101 0111 H A=+0000 0010 0101 0111 H=+599 8、设机器字长为8位,最高位为符号位,试对下列格式进行二进制补码运算,并判断结果是否溢出。 (1) 43+8 ∵[43]补=00101011B,[8]补=00001000B ∴[43]补+[8]补=00101011B+00001000B=00110011B=33H 00101011B +00001000B

微机原理课后习题解答

微机原理习题 第一章绪论 习题与答案 1、把下列二进制数转换成十进制数、十六进制数及BCD码形式。 (1) 10110010B= (2) 01011101、101B = 解: (1) 10110010B = 178D =B2H=(00010111 1000)BCD (2) 01011101、101B =93、625D=5D.AH =(1001 0011、0110 0010 0101)BCD 2. 把下列十进制数转换成二进制数。 (1) 100D= (2) 1000D= (3) 67、21D= 解: (1) 100D = 01100100B (2) 1000D=1111101000B (3) 67、21D=1000011、0011B 3. 把下列十六进制数转换成十进制数、二进制数。 (1) 2B5H = (2) 4CD、A5H= 解: (1) 2B5H = 693D = 00101011 0101B (2) 4CD、A5H=1229.6445D=0100 11001101.10100101B 4、计算下列各式。 (1) A7H+B8H = (2) E4H-A6H = 解: (1) A7H+B8H = 15FH (2) E4H-A6H =3EH 5、写出下列十进制数的原码、反码与补码。 (1)+89 (2)-37

解: (1) [+89 ] 原码、反码与补码为: 01011001B (2) [-37] 原码= 10100101 B [-37] 反码= 11011010 B [-37] 补码=11011011 B 6.求下列用二进制补码表示的十进制数 (1)(01001101)补= (2)(10110101)补= 解: (1)(01001101)补= 77D (2)(10110101)补=-75D 7.请用8位二进制数写出下列字符带奇校验的ASCII码。 (1)C: 1000011(2)O: 1001111 (3)M: 1001101 (4)P: 1010000 解: (1)C:0 1000011 (2)O: 01001111 (3)M:11001101 (4)P: 1 1010000 8、请用8位二进制数写出下列字符带偶校验的ASCII码。 (1)+:0101011 (2)=: 0111101 (3)#:0100011(4)>: 0111110 解: (1)+:00101011 (2)=: 10111101 (3)#:10100011 (4)>: 1 0111110 9、叙述CPU 中PC的作用。 解:PC就是CPU中的程序计数器,其作用就是提供要执行指令的地址。

微机原理王忠民版课后答案

部分习题答案 (3) 0.1101 1B= 0.84375 = 0.D8H (4) 11110.01 B= 30.25 =1E.4H 3、完成下列二进制数的加减法运算 (1) 1001.11 + 100.01 = 1110.0001110101.0110 (4) 01011101.0110 — 101101.1011 = 101111.1011 4、 完成下列十六进制数的加减法运算 (1) 745CH + 56DFH= D14B H (2) ABF.8H — EF6.AH = 9C28.E H (3) 12AB.F7 + 3CD.05= 1678 .FC H (4) 6F01H — EFD8H= 7F29 H 5、 计算下列表达式的值 103.CEH (3) 18.9 + 1010.1101B + 12.6H — 1011.1001 = 36.525 6、选取字长n 为8位和16位两种情况,求下列十进制数的补码。 (1) X=— 33的补码: ⑵ Y=+ 33的补码: 0010 0001 , 0000 0000 0010 0001 ⑶ Z=— 128 的补码:1000 0000 , 1111 1111 1000 0000 ⑷ N=+ 127的补码: 0111 1111 , 0000 0000 0111 1111 A=— 65的补码: 1011 1111 , 1111 1111 1011 1111 ⑹ B=+ 65的补码: 0100 0001 , 0000 0000 0100 0001 ⑺ C=— 96的补码: 1010 0000 , 1111 1111 1010 0000 (8) D=+ 96的补码: 0110 0000 , 0000 0000 0110 0000 7、写出下列用补码表示的二进制数的真值 (1) [X 补=1000 0000 0000 0000 H X = — 1000 0000 0000 0000 H =— 32768 (2) [Y 补=0000 0001 0000 0001 H Y = + 0000 0001 0000 0001 H = + 257 (3) [Z 补=1111 1110 1010 0101 H Z= — 0000 0001 0101 1011 H =—347 (4) [A 补=0000 0010 0101 0111 H A= + 0000 0010 0101 0111 H =+ 599 8、设机器字长为8位,最高位为符号位,试对下列格式进行二进制补码运算,并判断结果是否溢出。 (1) 43 + 8 [43]补=00101011B , [8]补=00001000B [43]补+ [8]补=00101011B + 00001000B = 00110011B = 33H 00101011B + 00001000B 00110011B T C s = 0, C D = 0, OF= C S ? C D = 0 ? 0= 0 ??? 无溢出 (1) 43 + 8 33H (无溢出) 第二章 1、 将十进制数转换为二进制和十六进制 (1) 129.75 = 1000 0001.11B = 81.CH (3) 15.625 = 1111.101B = F.AH 2、 将下列二进制数转换为十进制和十六进制 (1) 111010 B= 58 =3A H 计算机中的数值和编码 (2) 218.8125 = 1101 1010.1101B = DA.DH ⑷ 47.15625 = 10 1111.0010 1B = 2F.28 H (2) 1011 1100.111B= 188.875 = BC.E H (2) — 52 + 7 D3 H (无溢出)

微机原理习题解答

第一章微型计算机的基础知识 1-1 将下列十进制数转换为二进制数、十六进制数。 (1)110 (2)1 039 (3)0.75 (4)0.156 25 1-2 将下列十进制数转换为BCD 码。 (1)129 (2)5 678 (3)0.984 (4)93.745 1-3 将下列二进制数转换为十进制数、十六进制数。 (1)10101010 (2)10000000 (3)11000011.01 (4)01111110 1-4 将下列十六进制数转换为二进制数、十进制数。 (1)8E6H (2)0A42H (3)7E.C5H (4) 0F19.1DH 1-5 将下列二进制数转换为BCD 码。 (1)1011011.101 (2)1010110.001 1-6 将下列BCD 码转换为二进制数。 (1)(0010 0111 0011) BCD (2)(1001 0111.0010 0101) BCD 1-7 完成下列二进制数的运算。 (1)1001.11+11.11 (2)1101.01-0110.11 (3)1000.011-1001.101 (4)1111+1101 1-8 完成下列十六进制数的运算。 (1)6AH+0A6H (2)0AB1FH+0EFCH (3)12ADH-1DEH (4)117H-0ABH 1-9 已知X=01H,Y=0FFH ,在下面的情况下比较两数的大小。 (1)无符号数 (2)符号数 (均为补码) 1-10 计算下列各表达式。 (1)101+‘A’+01101001B+0D5H+57Q (2)127.8125+10111101.101+375.63Q+1FC.8AH 1-11 写出下列字符串的ASCII 码。 (1)HELLO (2)A8=

微机原理与接口技术(第二版)课后习题答案完整版

习题1 1.什么是汇编语言,汇编程序,和机器语言? 答:机器语言是用二进制代码表示的计算机能直接识别和执行的一种机器指令的集合。 汇编语言是面向及其的程序设计语言。在汇编语言中,用助记符代替操作码,用地址符号或标号代替地址码。这种用符号代替机器语言的二进制码,就把机器语言编程了汇编语言。 使用汇编语言编写的程序,机器不能直接识别,要由一种程序将汇编语言翻译成机器语言,这种起翻译作用的程序叫汇编程序。 2.微型计算机系统有哪些特点?具有这些特点的根本原因是什么? 答:微型计算机的特点:功能强,可靠性高,价格低廉,适应性强、系统设计灵活,周期短、见效快,体积小、重量轻、耗电省,维护方便。 这些特点是由于微型计算机广泛采用了集成度相当高的器件和部件,建立在微细加工工艺基础之上。 3.微型计算机系统由哪些功能部件组成?试说明“存储程序控制”的概念。 答:微型计算机系统的硬件主要由运算器、控制器、存储器、输入设备和输出设备组成。 “存储程序控制”的概念可简要地概括为以下几点: ①计算机(指硬件)应由运算器、存储器、控制器和输入/输出设备五大基本部件组成。 ②在计算机内部采用二进制来表示程序和数据。 ③将编好的程序和原始数据事先存入存储器中,然后再启动计算机工作,使计算机在不需要人工干预的情况下,自动、高速的从存储器中取出指令加以执行,这就是存储程序的基本含义。 ④五大部件以运算器为中心进行组织。 4.请说明微型计算机系统的工作过程。 答:微型计算机的基本工作过程是执行程序的过程,也就是CPU自动从程序存

放的第1个存储单元起,逐步取出指令、分析指令,并根据指令规定的操作类型和操作对象,执行指令规定的相关操作。如此重复,周而复始,直至执行完程序的所有指令,从而实现程序的基本功能。 5.试说明微处理器字长的意义。 答:微型机的字长是指由微处理器内部一次可以并行处理二进制代码的位数。它决定着计算机内部寄存器、ALU和数据总线的位数,反映了一台计算机的计算精度,直接影响着机器的硬件规模和造价。计算机的字长越大,其性能越优越。在完成同样精度的运算时,字长较长的微处理器比字长较短的微处理器运算速度快。 6.微机系统中采用的总线结构有几种类型?各有什么特点? 答:微机主板常用总线有系统总线、I/O总线、ISA总线、IPCI总线、AGP总线、IEEE1394总线、USB总线等类型。 7.将下列十进制数转换成二进制数、八进制数、十六进制数。 ①(4.75)10=(0100.11)2=(4.6)8=(4.C)16 ②(2.25)10=(10.01)2=(2.2)8=(2.8)16 ③(1.875)10=(1.111)2=(1.7)8=(1.E)16 8.将下列二进制数转换成十进制数。 ①(1011.011)2=(11.6)10 ②(1101.01011)2=(13.58)10 ③(111.001)2=(7.2)10 9.将下列十进制数转换成8421BCD码。 ① 2006=(0010 0000 0000 0110)BCD ② 123.456=(0001 0010 0011.0100 0101 0110)BCD 10.求下列带符号十进制数的8位基2码补码。 ① [+127]补= 01111111

相关主题
文本预览
相关文档 最新文档