计算机组成原理习题答案解析(蒋本珊)_第1页
计算机组成原理习题答案解析(蒋本珊)_第2页
计算机组成原理习题答案解析(蒋本珊)_第3页
计算机组成原理习题答案解析(蒋本珊)_第4页
计算机组成原理习题答案解析(蒋本珊)_第5页
已阅读5页,还剩97页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第一章

1.电子数字计算机和电子模拟计算机的区别在哪里?

解:电子数字计算机中处理的信息是在时间上离散的数字量,运

算的过程是不连续的;电子模拟计算机中处理的信息是连续变化的物

理量,运算的过程是连续的。

2.冯•诺依曼计算机的特点是什么?其中最主要的一点是什么?

解:冯・诺依曼计算机的特点如下:

①计算机(指硬件)应由运算器、存储器、控制器、输入设备和输

出设备五大基本部件组成;

②计算机内部采用二进制来表示指令和数据;

③将编好的程序和原始数据事先存入存储器中,然后再启动计算机

工作。

第③点是最主要的一点。

3.计算机的硬件是由哪些部件组成的?它们各有哪些功能?

解:计算机的硬件应由运算器、存储器、控制器、输入设备和输

出设备五大基本部件组成。它们各自的功能是:

①输入设备:把人们编好的程序和原始数据送到计算机中去,并且

将它们转换成计算机内部所能识别和接受的信息方式。

②输出设备:将计算机的处理结果以人或其他设备所能接受的形式

送出计算机。

③存储器:用来存放程序和数据。

④运算器:对信息进行处理和运算。

⑤控制器:按照人们预先确定的操作步骤,控制整个计算机的各部

件有条不紊地自动工作。

4.什么叫总线?简述单总线结构的特点。

解:总线是一组能为多个部件服务的公共信息传送线路,它能分

时地发送与接收各部件的信息。单总线结构即各大部件都连接在单一

的一组总线上,这个总线被称为系统总线。CPU与主存、CPU与外设

之间可以直接进行信息交换,主存与外设、外设与外设之间也可以直

接进行信息交换,而无须经过CPU的干预。

5.简单描述计算机的层次结构,说明各层次的主要特点。

解:现代计算机系统是一个硬件与软件组成的综合体,可以把它

看成是按功能划分的多级层次结构。

第0级为硬件组成的实体。

第1级是微程序级。这级的机器语言是微指令集,程序员用微指令

编写的微程序一般是直接由硬件执行的。

第2级是传统机器级。这级的机器语言是该机的指令集,程序员用

机器指令编写的程序可以由微程序进行解释。

第3级是操作系统级。从操作系统的基本功能来看,一方面它要直

接管理传统机器中的软硬件资源,另一方面它又是传统机器的延伸。

第4级是汇编语言级。这级的机器语言是汇编语言,完成汇编语言

翻译的程序叫做汇编程序。

第5级是高级语言级。这级的机器语言就是各种高级语言,通常用

编译程序来完成高级语言翻译的工作。

第6级是应用语言级。这一级是为了使计算机满足某种用途而专门

设计的,因此这一级语言就是各种面向问题的应用语言。

6.计算机系统的主要技术指标有哪些?

解:计算机系统的主要技术指标有:机器字长、数据通路宽度、

主存容量和运算速度等。

机器字长是指参与运算的数的基本位数,它是由加法器、寄存器的位

数决定的。

数据通路宽度是指数据总线一次所能并行传送信息的位数。

主存容量是指主存储器所能存储的全部信息量。

运算速度与机器的主频、执行什么样的操作、主存本身的速度等许多

因素有关。

第二章

1.设机器数的字长8位(含1位符号位),分别写出下列各二

进制数的原码、补码和

反码:0,—0,0.1000,—0.1000,0.1

111,-0.1111,1101,-11010

解:

真值原码补码反码

0000000000000000000000000

-0100000000000000011111111

0.10000.10000000.10000000.1000000

-0.10001.10000001.10000001.0111111

0.11110.11110000.11110000.1111000

-0.11111.11110001.00010001.0000111

1101000011010000110100001101

—1101100011011111001111110010

2.写出下列各数的原码、补码和反码1.±0.一七一■,一父

lblblblblblb

解:以=7X2-,=0.0Ul

-^=4X2-1=0.0100

i=lX2-1=0.0001

真值原码补码反码

L0.01110.01110.0111

1690.01000.01000.0100

,0.0001

0.00010.0001

0.00000.00000.0000

1.00000.00001.1111

-Ho1.00011.11111.1110

J

1.01001.11001.1011

J

1.01111.10011.1000

M

3.已知下列数的原码表示,分别写出它们的补码表示:

[X1]原=0.10100,[X2]原=1.10111o

解:[X1]补=0.10100,[X2]补=1.0100

1

4.已知下列数的补码表示,分别写出它们的真值:

[X1]补=0.10100,[X2]补=1.10111

解:X1=0.10100,X2=-0.01001o

5.设-一个二进制小数X沁,表示成X=0"aa°aa,其中a〜&取“1”或“0”

(1)若要〜*要满足什么条件?

(2)若要存方.。〜。要满足什么条件?

(3)若要《为X>±.Q〜a要满足什么条件?

解:(1)X1土的代码为:0」00001-0111111。

Q=1,a-侬—s+3+a=lo

(2)•的代码为:

0.0010003

O

0.111111史

64

Q+Q=O,0=1或Q=0,a=I或a=lo

(3)士土的代码为:

0.000101系

b4

0.0100005

s+a-CB=0,O=1,€B-H«=1aga+a=O.0=]或a=l,Q+a+a+a+

0=0。

<1>若婺~s筌满足什么条件?

C2>若要一专*X*—亡,s-s耍,背足什么条件?

解:<1)一+白勺£弋"5为:

1.OOOOO1一

1.01X111一沔

6O«Ct0«4-Hg-Hs=J.o

(二)—d-三x*—+口勺Ji讨g为:

O-i

1.ooiooo----o£-

1.ooiooi—必

1.OOllll一0-4

1.oioooo----

。。-

-HaO,e1sice-He-HsHs-HsOo

7.若上题中[X%改为[X>,结果如何?

解:设[X*=1.aaa很行®,

(1)£>一十的代码为:

_31

1.100001

64

-L

1.111111

64

0=1,a+°+o+a+a=lo

(2)一女)4一十的代码为:

__L

1.110000

4

_15

1.110001

64

__9.

1.110111

64

1.111000

8

CD•a=l,<s=O或a,a:•a=1,a+rs+a=0

8.一个n位字长的二进制定点整数,其中1位为符号位,分别

写出在补码和反码两

种情况下:

(1)模数;(2)最大的正数;

(3)最负的数;(4)符号位的权;

(5)1的表示形式;(6)0的表示形式。

解:

项目补码反码

模数Mod2"Mod

最大的正数2,1-12**-1

11

最负的数—9"一⑵一D

符号位的权nn1>1

-1的袅示形式1111111111111110

00000000

。的袅示形式00000000

11111111

9.某机字长16位,问在下列几种情况下所能表示数值的范围:

(1)无符号整数;(2)用原码表示定点小数;

(3)用补码表示定点小数;(4)用原码表示定点整数;

(5)用补码表示定点整数。

解:(1)0<%«216-1)

(2)-(l-2-ls)<X«l-2-ls)

(3)-1-—2T5)

(4)-(215-1)<X<(215-1)

(5)一2-(215-1)

10.某机字长32位,试分别写出无符号整数和带符号整数(补

码)的表示范围(用十

进制数表示)。

解:无符号整数:04看〈(2纪一1)。

补码:一23yx《2”

11.某浮点数字长12位,其中阶符1位,阶码数值3位,数

符1位,尾数数值7位,阶码以2为底,阶码和尾数均用补码表

示。它所能表示的最大正数是多少?最小规格化正数是多少?绝对

值最大的负数是多少?

解:最大正数=(1一2一)X炉"T=(1-2-7)*2'=127。

最小规格化正数=2一】X2-=2-X2-8=27=+.

7

绝对值最大的负数=一lx/-=-1X2=-128O

12.某浮点数字长16位,其中阶码部分6位(含1位阶符),

移码表示,以2为底;尾

数部分1。位(含1位数符,位于尾数最高位),补码表示,规

格化。分别写出下列各题的二

进制代码与十进制真值。

(1)非零最小正数;

(2)最大正数;

(3)绝对值最小负数;

(4)绝对值最大负数。

解:(1)非零最小止数:000000,0.100000000;2TX2Y=2一"0

25-I-931

(2)最大正数jllllll.O,111111111;(1一2T)X2=(1-2)X2O

(3)绝对值最小负数:000000,1,011111111;-(2-1+2-4)X2-*。

(4)绝对值最大负数,000000000=-2”。

13.一浮点数,其阶码部分为p位,尾数部分为q位,各包含1

位符号位,均用补码表

示;尾数基数r=2,该浮点数格式所能表示数的上限、下限及

非零的最小正数是多少?写

数据的机器层次表示出表达式。

解:上限(最大正数)=(1一2-"-。)*/'

下限(绝对值最大负数)=一1乂对‘

最小正数=2-<fX2-2”二

最小规格化正数=2TX2-2"二

14.若上题尾数基数r=16,按上述要求写出表达式。

解:上限(最大正数)=(1一2一37)X16?”“一,

下限(绝对值最大负数)=-1X16?”'一

最小正数MZ-XWT""。

最小规格化正数=16"X167"“.

15.某浮点数字长32位,格式如下。其中阶码部分8位,以

2为底,移码表示;尾数部分一共24位(含1位数符),补码

表示。现有一浮点代码为(8C5A3E00)16,试写出它所表示

的十进制真值。

07893

阶码数符尾数

解:(8C5A3E00>6=10001100010110100011111000000000B.

!

0.10110100011111X2-=(101101000111.11>=(2887.75)io0

16.试将(一0.1101)2用IEEE短浮点数格式表示

出来。

解:-1

0.1101=1.101X2o

符号位=1。

阶码=127—1=126。

1,01111110,10100000000000000000000o

结果=BF500000H。

17.将下列十进制数转换为IEEE短浮点数:

解:(4

1)28.75=11100.11=1.110011X2o

符号位=0。

阶码=127+4=131。

0,10000011,110011000000000000000000

结果=41E60000H。

9

(2)624=1001110000=1.001110000X2o

符号位=0。

阶码=127+9=136。

0,10001000,00111000000000000000000o

结果=441C0000H。

-

(3)—0.625=—0.101=-1.01X2'o

符号位=1。

阶码=127-1=126。

1.01111110,01000000000000000000000,

结果=BF200000H。

(4)+0.0。

结果=00000000H。

,

(5)-1000.5=1111101000.1=1.1111010001X2o

符号位=1。

阶码=127+9=136。

1,10001000,illlOlOOOlOOOOOOOOOOOOOo

结果=C47A2000H。

18.将下列IEEE短浮点数转换为十进制数:

(1)11OOOOOO1111OOOOOOOOOOOO0

OOOOOOO;

(2)0011111100010000000000000

0000000;

(3)0100001110011001000000000

0000000;

(4)0100000000000000000000000

0000000;

(5)0100000100100000000000000

0000000;

(6)0000000000000000000000000

0000000o

解:(1)1,10000001.11100000000000000000000

符号位=L

阶码=129—127=2。

2

1.111X2=111.1B=7.58

所以结果=一7.5。

(2)0,01111110,00100000000000000000000

符号位=0。

阶码=126—127=

1.001X2-1=0.1001B=0.5625。

所以,结果=0.5625。

(3)0,10000111,00110010000000000000000

符号位=0。

阶码=135—127=8。

8

1.0011001X2=100110010B=306o

所以,结果=306。

(4)0,10000000,00000000000000000000000

符号位=0。

阶码=128—127=1。

1

1.0X2=10B=2o

所以,结果=2。

(5)0,10000010,01000000000000000000000

符号位=0。

阶码=130-127=3。

3

1.01X2=1010B=10o

所以,结果=10。

(6)0,00000000,00000000000000000000000

阶码和尾数都等于全0,结果=0。

19.对下列ASCII码进行译码:

1001001,0100001,1100001,1110

111

1000101,1010000,1010111,0100

100

解:以上ASCII码分别为I,ba,w,E,P,W.$。

20.以下列形式表示(5382)10o

(1)8421码;(2)余3码;

(3)2421码;(4)二进制数。

解:(1)0101001110000010.

(2)1000011010110101.

(3)1011001111100010,

(4)1010100000110,

21.填写下列代码的奇偶校验位,现设为奇校验:

10100001

00011001

01001110

解:3个代码的校验位分别是0,0,1。

22.已知下面数据块约定:横向校验、纵向校验均为奇校验,请

指出至少有多少位出错。

aaQk(zQ(D校验位

10011011-0

00110101-1

1101000o-*0

11100000f0

01001111-*0

▼1TVTV1

校验位10101111

解:经检测<B和。列出错,所以至少有两位出错。

23.求有效信息位为。1101110的海明校验码。

解:P5D8D7D6D5P4D4D3D2P3DlP2Pl

P1=D1㊉D2㊉D4㊉D5㊉D7=0㊉1㊉I㊉。㊉1=1

P2=D1㊉D3㊉D4㊉D6㊉D7=0㊉1㊉1㊉1㊉1=0

P3=D2㊉D3㊉D4㊉D8=1㊉1㊉1㊉0=1

P4=D5㊉D6㊉D7㊉D8=0㊉1㊉1㊉0=0

P5=D1㊉D2㊉D3㊉D5㊉D6㊉D8=0㊉1㊉1㊉0㊉1㊉0=1

所以,海明校验码=10U0QU110Ql,

24.设计算机准备传送的信息是:1010110010001

111,生成多项式是X5+X2+1,计算校验位,写出CRC

码。

5:

解:生成多项式X+X+l=100101o

首先将准备传送的信息左移5位;101011001000111100000o

然后1010110010001111000004-100101,余数=10011。

所以,CRC码=101011001000111110011。

第三章

1.指令长度和机器字长有什么关系?半字长指令、单字长指令、

双字长指令分别表示什么意思?

解:指令长度与机器字长没有固定的关系,指令长度可以等于机

器字长,也可以大于或小于机器字长。通常,把指令长度等于机器字

长的指令称为单字长指令;指令长度等于半个机器字长的指令称为半

字长指令;指令长度等于两个机器字长的指令称为双字长指令。

2.零地址指令的操作数来自哪里?一地址指令中,另一个操作数

的地址通常可采用什么寻址方式获得?各举一例说明。

解:双操作数的零地址指令的操作数来自堆栈的栈顶和次栈顶。

双操作数的一地址指令的另一个操作数通常可采用隐含寻址方式获

得,即将另一操作数预先存放在累加器中。例如,前述零地址和一地

址的加法指令。

3.某机为定长指令字结构,指令长度16位;每个操作数的地址

码长6位,指令分为无操作数、单操作数和双操作数三类。若双操

作数指令已有K种,无操作数指令已有L种,问单操作数指令最多可

能有多少种?上述三类指令各自允许的最大指令条数是多少?

解:X=(24-K)X2•一步k

双操作数指令的最大指令数:2*一1。

单操作数指令的最大指令数J5X26-1(假设双操作数指令仅1条.为无操作数指

令留出1个扩展窗口)。

无操作数指令的最大指令数:216一2”-2s。其中212为表示某条二地址指令占用的

编码数,2,为表示某条单地址指令占用的编码数。此时双操作数和单操作数指令各仅有

1条。

4.设某机为定长指令字结构,指令长度12位,每个地址码占3

位,试提出一种分配

方案,使该指令系统包含:4条三地址指令,8条二地址指令,1

80条单地址指令。

解:4条三地址指一令

OOOXXXYYYZZZ

OliXXXYYYZZZ

8条二地士1上指令

1OOOOOXXXYYY

1OOillXXXYYY

180条单地力上指令

1O1OOOOOOXXX

111IIOOilXXX

5.指令格式同上题,能否构成:三地址指令4条,单地址指令2

55条,零地址指令64条?为什么?

解:三地址指令4条

000XXXYYYZZZ

011XXXYYYZZZ

单地址指令255条

100000000XXX

111111110YYY

只能再扩展出零地址指令8条,所以不能构成这样的指令系统。

6.指令中地址码的位数与直接访问的主存容量和最小寻址单位有

什么关系?

解:主存容量越大,所需的地址码位数就越长。对于相同容量

来说,最小寻址单位越小,地址码的位数就越长。

7.试比较间接寻址和寄存器间址。

解:间接寻址方式的有效地址在主存中,操作数也在主存中;寄

存器间址方式的有效地址在寄存器中,操作数在主存中。所以间接寻

址比较慢。

8.试比较基址寻址和变址寻址。

解:基址寻址和变址寻址在形成有效地址时所用的算法是相同

的,但是它们两者实际上是有区别的。一般来说,变址寻址中变址寄

存器提供修改量(可变的),而指令中提供基准值(固定的);基

址寻址中基址寄存器提供基准值(固定的),而指令中提供位移量

(可变的)。这两种寻址方式应用的场合也不同,变址寻址是面向

用户的,用于访问字符串、向量和数组等成批数据;而基址寻址面向

系统,主要用于逻辑地址和物理地址的变换,用以解决程序在主存中

的再定位和扩大寻址空间等问题。在某些大型机中,基址寄存器只能

由特权指令来管理,用户指令无权操作和修改。

9.某机字长为16位,主存容量为64K字,采用单字长单地址

指令,共有50条指令。若有直接寻址、间接寻址、变址寻址、相

对寻址四种寻址方式,试设计其指令格式。

解:操作码6位,寻址方式2位,地址码8位。

10.某机字长为16位,主存容量为64K字,指令格式为单字

长单地址,共有64条指令。试说明:

(1)若只采用直接寻址方式,指令能访问多少主存单元?

(2)为扩充指令的寻址范围,可采用直接/间接寻址方式,若只

增加一位直接/间接标志,指令可寻址范围为多少?指令直接寻址

的范围为多少?

(3)采用页面寻址方式,若只增加一位Z/C(零页/现行页)标

志,指令寻址范围为多少?指令直接寻址范围为多少?

(4)采用(2)、(3)两种方式结合,指令的寻址范围为多

少?指令直接寻址范围为多少?

解:因为计算机中共有64条指令,所以操作码占6位,其余部分为地址码或标志位。

(1)若只采用直接寻址方式,地址码部分为10位,指令能访问的主存单元数为限=

1K字。

(2)若采用直接/间接寻址方式,将增加了一位直接/间接标志,地址码部分为9位.

指令直接寻址的范围为29=0.5K字,指令可寻址范围为整个主存空间2U-G4K字。

(3)若采用页面寻址方式,将增加一位Z/C(零页/现行页)标志,所以指令直接寻址

范围仍为29=0.5K字,指令寻址范围仍为216=64K字。

(4)此时将需酶和Z/C两个标志位.所以指令直接寻址范围为2s=0.25K字,指

令的可寻址范围仍为2"=64K字。

11.设某机字长32位,CPU有32个32位的通用寄存器,

设计一个能容纳64种操作的单字长指令系统。

(1)如果是存储器间接寻址方式的寄存器一存储器型指令,能直

接寻址的最大主存空间是多少?

(2)如果采用通用寄存器作为基址寄存器,能直接寻址的最大主

存空间又是多少?

解:因为计算机中共有64条指令,所以操作码占6位;32

个通用寄存器,寄存器编号占5位;其余部分为地址码或标志位。

(1)如果是存储器间接寻址方式的寄存器一存储器型指令,操作

码6位,寄存器编号5位,间址标志1位,地址码20位,直接

寻址的最大主存空间是力•字O

(2)如果采用通用寄存器作为基址寄存器,EA=(R>.)-A,能直

接寻址的最大主存空间是2契字。

12.已知某小型机字长为16位,其双操作数指令的格式如下:

0567815

0PRA

其中:0P为操作码,R为通用寄存器地址。试说明下列各种情况下

能访问的最大主存区域有多少机器字?

(1)A为立即数。

(2)A为直接主存单元地址。

(3)A为间接地址(非多重间址)。

(4)A为变址寻址的形式地址,假定变址寄存器为R1(字长为

16位)

解:(1)1个机器字。

(2)256个机器字。

(3)65536个机器字。

(4)65536个机器字。

13.计算下列4条指令的有效地址(指令长度为16位)。

(1)000000Q(2)100000Q(3)170710Q

(4)012305Q

假定:上述4条指令均用八进制书写,指令的最左边是一位间址指示位@Q=0,直

接?址@=1,间接寻址),且具有多重间访功能:指令的最右边两位为旧式地址:主存容

量限单元,表3-4为有关主存单元的内容(八进制)。

表左4习题13的表格解:(1)000000Q

地址内容因为指令的最高位为0,故为直接寻址,EA=

00000100002A=00000Q0

00001046710(2)100000Q

00002054304因为指令的最高位为1.故指令为间接寻址。

00003100000(00000)=100002,最高位仍为1,继续间接寻址。

00004102543(00002)=054304,其最高位为0,表示已找到有效

00005100001地址,EA=54304Q0

00006063215(3)170710Q

00007077710因为指令的最高位为1.故指令为间接寻址,

00010100005(00010)=100005,最高位仍为1,继续间接寻址。

(00005)=100001,最高位仍为1.继续间接寻址,

(00001)=046710,其最高位为0,表示已找到有效地址,EA=46710Q。

(4)012305Q

因为指令的最高位为0,故为直接W址.EA=A=00005Q。

14.假定某机的指令侪式如下:

1110987650

©OP11LZ/CA

其中:

址:

Bit8=I:变址寄存器1>寻址;

B“7=l:变址寄存器k寻址;

Bit6(零页/现行页寻址):Z/C=0,表示0页面:

Z/C=l,表示现行页面,即指令所在页面。

若主存容量为小个存储单元,分为2°个页面.每个页面有26个字。

设有关寄存器的内容为

(PC)=0340Q(Ii)=1111Q(1=)=0256Q

试计算下列指令的有效地址。

(1)1046Q

(2)2433Q

(3)3215Q

(4)1111Q

解:(1)1046Q=001000100110

因4个位均为。♦故直接寻•At»EAA^0046Qe

(2)2433Q=010100OilOil

因为)=1.故为变址寄存器1寻址,EA=(Ti)-1-A=1111-(-33=11449),

(3)3215Q=011010001101

因为Bit7(I2)=i,故为变址寄存器2寻址,EA=(L)+A=0256+I5=0273Q。

<4)1111Q=OO1001001001

因为Bit6(Z/C>=1,故为当前页寻址.EA=(PC)”〃A=O3〃11=O31IQ。

15.假定指令格式如下:

151211109870

OPLkz/cD/IA

其中:D/I为直接/间接寻址标志,D/I=O表示直接寻址,D/I=l表示间接寻址。其

余标志位同题14说明。

若主存容量为*个存储单元,分为2*个页面.每个页面有2s个字。

设有关寄存器的内容为

(Ii)=002543Q(I:)=063215Q(PC)=004350Q

试计算下列指令的有效地址。

(1)152301Q

(2)074013Q

(3)161123Q

(4)140011Q

解:Q)152301(?=1101010011000001

因为BitlO(L)=I.故为变址寄存器2寻址,EA=(fc)+A=063215+

301=063516Qo

(2)074013Q=0ill100000001011

因为Bitll(h)=i,故为变址寄存器1寻址,EA=(I:)+A=002543+

013=002556Qo

(3)161i23Q=l110001001010Oil

因为Bit9(Z/C)=1,故为当前页寻址,EA=(PC)//A=004123Qo

(4)1400ilQ=liOO000000OOi001

因为4个标志位均为0,故为直接寻址,EA=A=000011Qo

16.举例说明哪几种寻址方式除去取指令以外不访问存储器?哪

几种寻址方式除去取指令外只需访问一次存储器?完成什么样的指

令,包括取指令在内共访问4次存储器?

解:除去取指令以外不访问存储器:立即寻址,寄存器寻址。

除去取指令外只需访问一次存储器:直接寻址,寄存器间接寻址,变

址寻址,基址寻址,相对寻址,页面寻址。

二级间接寻址包括取指令在内共访问4次存储器。

17.设相对寻址的转移指令占两个字节,第一个字节是操作码,

第二个字节是相对位移量,用补码表示。假设当前转移指令第一字节

所在的地址为2000H,且CPU每取一个字节便自动完成(PC)+1

TPC的操作。试问当执行JMP*+8和JMP*-9指令(倡为

相对寻址特征)时,转移指令第二字节的内容各为多少?转移的目

的地址各是什么?

解:转移指令第二字节的内容分别为:00001000(+8),11110111

(―9)

转移的目的地址分别为:200AH,1FF9H。

20.什么叫主程序和子程序?调用子程序时还可采用哪几种方法保

存返回地址?画图说明调用子程序的过程。

解:主程序就是指通常的程序,而子程序是一组可以公用的指令

序列,只要知道子程序的入口地址就能调用它。

保存返回地址的方法有多种:

(1)用子程序的第一个字单元存放返回地址。转子指令把返回地

址存放在子程序的第一个字单元中,子程序从第二个字单元开始执

行。返回时将第一个字单元地址作为间接地址,采用间址方式返回主

程序。

(2)用寄存器存放返回地址。转子指令先把返回地址放到某一个

寄存器中,再由子程序将寄存器中的内容转移到另一个安全的地方。

(3)用堆栈保存返回地址。

调用子程序的过程如图3唱8所示,此时返回地址保存在堆栈中。

王程序于腥序

A:-------------

K:CALLA-/Z//Z--------------

Af+1:----------------------------------------

-------------'''"'''RET

图3-8主程序谢用子程序的过程

21.在某些计算机中,调用子程序的方法是这样实现的:转子指令

将返回地址存入子程序的第一个字单元,然后从第二个字单元开始执

行子程序,请回答下列问题:

(1)为这种方法设计一条从子程序转到主程序的返回指令。

(2)在这种情况下,怎么在主、子程序间进行参数的传递?

(3)上述方法是否可用于子程序的嵌套?

(4)上述方法是否可用于子程序的递归(即某个子程序自己调用

自己)?

(5)如果改用堆栈方法,是否可实现(4)所提出的问题?

解:(1)返回指令通常为零地址指令。返回地址保存在堆栈

中,执行返回指令时自动从堆栈中弹出。而目前返回地址是保存在子

程序的第一个单元中,故此时返回指令不能再是零地址指令了,而应

当是一地址指令。如:

JMP子程序首地址

间接寻址可找到返回地址,然后无条件转移到返回的位置。

(2)在这种情况下,可利用寄存器或主存单元进行主、子程序间

的参数传递。

(3)可以用于子程序的嵌套(多重转子)。因为每个返回地址都

放在调用的子程序的第一个单元中。

(4)不可以用于子程序的递归,因为当某个子程序自己调用自己

时,子程序第一个单元的内容将被破坏。

(5)如果改用堆栈方法,可以实现子程序的递归,因堆栈具有后

进先出的功能。

第四章

1.证明在全加器里,进位传递函数—4,+8=人㊉8。

解:并行加法器中的每一个全加器都有一个从低位送来的进位和

一个传送给较高位的进位。进位表达式为•="B+(人㊉氏)C7欲证

明P=.4,+B=4,㊉也就是要证明

C,=/IE+(4®A.)CT=AB+(4+B)CT

用卡诺图法,图4-10(a)和4-10(b)分别是两个逻辑表达式

的卡诺图。两个卡诺图相同,两个逻辑表达式就相等,则进位传递函

数的两种形式相等。

2.某加法器采用组内并行、组间并行的进位链,4

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论