2023年兰州理工大学微机原理习题集作业答案章_第1页
2023年兰州理工大学微机原理习题集作业答案章_第2页
2023年兰州理工大学微机原理习题集作业答案章_第3页
2023年兰州理工大学微机原理习题集作业答案章_第4页
2023年兰州理工大学微机原理习题集作业答案章_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

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

文档简介

第一章微si计算机概论

1.1、答:微型计算机系统涉及硬件系统和软件系统两大部分。硬件系统涉及:

微型计算机、外部设备、电源及其它辅助设备。软件系统涉及:系统软件和应用软

件。

微型计算机也称为主机,主机涉及:微解决器、存储器、输入/输出接口(Input

/Output),微解决器通过系统总线和存储器、输入/输出接口进行连接。

微解决器(MicroprocessorUnit)简称为MPU(或者称为MP),它是一个中

央控制器(CentralProcessingUnit),简称CPU。它是微型计算机的核心

部件,它将运算器、控制器、寄存器通过内部总线连接在一起,并集成在一个独立

芯片上。

1.2、答:单片机是将CPU、ROM、RAM以及I/O接口电路以及内部系统总

线等所有集中在一块大规模集成电路芯片上,就构成了单片机。

单板机是将微解决器芯片、存储器芯片、I/O接口芯片及少量的输入输出设备

(键盘,数码显示器)安装在一块印制板上构成一台微型计算机。

由多块印制板构成的微机称为多板机。

1.3、完毕下列转换(保存4位小数)

(21.32)io=(10101.0101)2=(25.2436)$=(15.51EB)16

50.38D=110010.0110B=62.3024Q=32.6147H

1.4、完毕下列计算

已知X=-63,Y=59

则[X%=BFH(1011111lB),[X]s=C0H(B),[X]»=C1H(11000001B)

IY]S=3BH(00111011B),[Y]反=3BH(00111011B),[Y]H=3BH(001

11011B)

[X+Y]扑=OFCH(111111OOB),[X-Y]*=86H(10000110B)。

[X]ti+[Y]lh=:0FCH(111111OOB),[X])b-[g]fi=86H(1000011

OB)。

1.5、答:浮点数是指小数点在数值中的位置不是固定不变,实际位置将随阶码

而浮动,用这种方法表达的数,称为浮点数。

定点数是指小数点在数值中的位置固定不变。

1.6、答:压缩BCD码是4位二进制表达一位十进制数而非压缩BCD码是8

位二进制表达一位十进制数。

1.7、写出下列数值的压缩的BDC码、非压缩的BDC码、ASCII码值。

(改为15,29)

15=[15H]ffifBBCDH=[0105H]BCD«=[3135H]AscnH

29=[29H]压缩BCD码=[0209H]非IE缩BCD码=[3239H]Ascn码

第二章8086/8088微解决器

2.1答:从功能上讲由两部分组成总线接口单元BIU和执行单元EU组

成。

总线接口单元(BIU)是微解决器内部与存储器和I/O接口传送信息的通道,总

线接口单元负责从内存中将指令送到指令队列中;负责把数据从内存或I/O接口送

到执行单元(EU);负责将执行单元的运营结果送到内存或I/O接口。

EU的功能是负责译码和执行指令。

2.2答:指令队列(Queue)存放预取的指令,采用预取指令的方法将减少微解

决器的等待时间,提高运营效率。8086CPU中指令队列有6个;8088CPU中指令队

列有只有4个。

2.3答:8086/8088CPU中有16个16位的寄存器。4个段地址寄存器是代

码段寄存器CS;数据段寄存器DS;堆栈段寄存器SS和扩展段寄存器ES。它们是

用来存放每一个段的首地址(段基地址)。一个指令指针寄存器IP是用于存放要执行

的指令的偏移地址,它不能作为一般寄存器使用。一个标志寄存器(又称为程序状态

寄存器)用于反映指令执行结果或控制指令执行形式。)有8个通用寄存器,通用寄

存器分为数据寄存器与指针和变址寄存器两组。数据寄存器涉及AX(累加器)、BX

(基址寄存器)、CX(计数器)和DX(数据寄存器),一般用来存放16位数据,故称为数

据寄存器。其中的每一个又可根据需要将高8位和低8位提成独立的两个8位寄存

器来使用,即AH、BH、CH、DH和AL、BL、CL、DL两组,用于存放8位数据,

它们均可独立寻址、独立使用。数据寄存器用来存放计算的结果和操作数,也可以存

放地址。

指针寄存器涉及堆栈指针寄存器SP、基址指针寄存器BP一般用来存放地址的

偏移量和用于寻址内存堆栈内的数据

变址寄存器涉及原变址寄存器SI和目的变址寄存器DI,一般用来存放地址的偏

移量为存储器寻址时提供地址。

2.4答:标志寄存器又称为程序状态寄存器,是一个16位的寄存器,标志寄

存器设立了9个标志位。这9个标志位按功能分可以分为两类:一类为状态标志,

状态标志表达执行某种操作后,ALU所处的状态特性,这些状态标志会影响后面的

具体操作。状态标志有6个:CF、AF、SF、PF、OF和ZF。另一类为控制标志,

用来控制CPU操作,反映存储器地址变化的方向、是否允许中断及在执行程序时是

否进行单步中断。控制标志有3个:DF、IF和TF控制标志是人为设立的,每个

控制标志都对某种特定的功能起控制作用。

2.5答:8086与8088有3点不同之处;1.8086有16条数据线而8088

只有8条数据线,2.8086砺/MX而8088“N/麻。3.8086M/万而8088而//o.

2.6答:堆栈是在内存中开辟的一个特定的区域,用以存放CPU寄存器或存储

器中暂时不用的数据和有用的信息。在数据段和附加段存放数据时,一般是从低地址

开始向高地址存放数据,而用PUSH指令向堆栈中存放数据时总是从高地址开始逐

渐向低地址方向增长。堆栈指令遵循“先进后出”,"后进先出”的原则,凡是用PUSH指

令最后推入堆栈的数据,用POP指令弹出时最先出栈。在操作时是以字为单位。

2.7答:8086/8088CPU各有20根地址总线,可寻址范围是1M个存储单元。

8086CPU有16根数据,一次可以读一个字也可以读一个字节。8088CPU有8

数据总线一次以读一个字节。

2.8答:1.物理地址就是实际地址,它具有20位的地址值,它是唯一标志1

MB存储空间的某一单元的地址。2.逻辑地址由段基址和偏移量组成。程序以逻辑

地址编址,而不是物理地址。3.在8086/8088存储空间中,把16个字节的存储

空间看作一节。为了简化操作,规定各个逻辑段从节的整数边界开始,也就是说段首地

址低4位应当是“0”,因此把段首地址的高16位称为“段基值”。4.偏移量是该

物理地址距离段首地址的单元数。

2.9答:总线上传输信号的一组导线,作为微机各部件之间信息传输的公共通

道。系统总线按功能分数据总线、地址总线、控制总线。

2.10答:1.8086/8088CPU把存储器分为代码段、数据段、堆栈段、附加段。

由于8086/8088的寄存器是16位,最大只能寻址64K个单元的存储空间,为了增大

寻址空间把存储器进行分段,这样就可以寻址1MB存储空间。2.每段最大空间为

64KB。

2.11答:(l)2300H;1010H;24010H(2)0000H;1000H;0100

0H

(3)2AE0H;1690H;2C490H(4)7369H;0010H;736A0H

2.12答:1.数据段首地址是12023H末地址是21FFFH02.附加段的首地址是

20A30H末地址是30A2FH。3.代码段的首地址是470E0H=470EHxl0H末

地址是570DFH=(470E0H+FFFFH)。

2.13答:8086/8088CPU复位以后,除代码段寄存器外,其余标志寄存器、指

令指针寄存器、各段寄存器及指令对列所有被清零。

2.14答:在一个读总线周期ALE在第一个时钟周期为高电平,其余周期为低电

平。由正/S?在第一个时钟周期为低电平,其余周期为高电平。丽在第一个时钟周

期为低电平,第二、三周期为高电平。标一直为高电平。M/元一直为高电平。

DT/k一直为低电平。

2.15答:1.8086CPU读/写总线周期时,最少包含4个时钟周期。2.CPU在T

3状态的前沿(下降沿)对Ready信号进行采样。若CPU在T3状态的开始采样到Ready

信号为低电平,那么将在T3和T4之间插入等待状态Tw。3.Tw可以是一个,也可以

是多个。CPU在每个Tw的前沿处对Ready信号进行采样。当在Tw状态采样到

READY信号为高电平时,在当前Tw状态执行完,进入T4状态。

第三章存储器

3.1答:1.容量:存储器芯片的容量是以1位二进制数(bit)为单位,因此存储

器容量是指每一个存储器芯片所能存储的二进制数的位数。(存储器容量=存储单元

数x位数)芯片数量(N)=£统容量2.存储速度:存储器的基本操作是读出与写入,

芯片容量

称为“访问”或“存取”。存储器的存储速度有两个时间参数:(1)访问时间(Acce

ssTime)「从启动一次存储器操作,到完毕该操作所经历的时间。(2)存储周

期(MemoryCycle)加启动两次独立的存储器操作之间所需的最小时间间隔。

3.存储器的可靠性:4.性能/价格比:5.其他指标(存储器的选择有时还应考虑功

耗、集成度等指标)。

3.2答:按存储器的读写功能分可以分为随机读写存储器(RAM)和只读存储器

(ROM)。随机读写存储器RAM可以随机地按指定地址从存储单元存入或读取(简称存取)

数据,存放在RAM中的信息,一旦掉电就会丢失。

随机读写存储器RAM可分为静态随机存取存储器SRAM、动态随机存取存储器DRA

M和集成随机读写存储器IRAMo

只读存储器(ROM)的基本特性是在正常运营中只能随机读取预先存入的信息,即使

在断电情况下,ROM仍能长期保存信息内容不变,所以它是一种永久存储器。

只读存储器(ROM)可分为掩膜只读存储器(MaskROM)、可编程只读存楮器(PR

0M)、紫外线可擦除可编程只读存储器(EPROM)、电可擦除编程只读存储器(E/PROM)

和快速可擦编成只读存储器(FlashEPROM)。

掩膜只读存储器其结构简朴,存储信息稳定,可靠性高,可以永久性保存信息;可

编程只读存储器是由半导体厂家制作“空白”存储器阵列(即所有存储单元所有为1或

所有为0状态)出售,用户根据需要可以实现现场编程写入,但只能实现一次编程;紫

外线可擦编程只读存储器、电可擦除编程只读存储器和快可擦编程只读存储器等不仅可

以现场编程。还可以擦除原存储的信息内容,写入新的信息。

3.3答:SRAM的特点是在一个存储单元所用晶体管数目多,但不需要刷新电路。D

RAM的特点是在一个存储单元所用晶体管数目少,但需要刷新电路。[RAM的特点是将动

态随机存取存储器和刷新电路集成在一片芯片中,它即具有SRAM速度快的优点,又具有

DRAM的便宜。IRAM事实上是附有刷新电路的DRAM。它在现代微机系统中得到广泛

应用,大容量的内存一般都是用IRAM。

3.4答:1)13条地址线和4条数据线;2)19条地址线和1条数据线

3)17条地址线和4条数据线;4)15条地址线和8条数据线

3.5答:I)RAM的存储容量为256Kx8bit;2)有18条地址线和8条数据线;3)

若采用6116需要128片,若采用6264需要32片,若采用62128需要16片,若采

用2114需要512片,若采用2141需要512片。

3.6答:1)ROM的存储容量为512Kx8bit;2)需要19条地址线和8

条数据线;3)若采用2764需要64片,若采用27128需要32片,若采用281

6A需要256片,若采用28F256需要16片。

3.7答:常用的存储器片选控制方法有线选法、全译码法和部分译码法。

线选法地址线可以不用完,也无需专门的译码电路。但由于高位地址线可随意取

值0或1。所以,存在地址重叠,并且导致存储器地址不能连续分布。

全译码法所有地址线均参与地址译码,芯片的地址线直接和低位地址总线相

连,高位地址总线经译码器或逻辑电路与各芯片的片选信号相连。

部分译码法与全译码法类似,只是高位地址线中有一部分进行译码,产生片选

信号,而不是所有。这种方法称为部分译码法。

3.8答:第一片的首地址为210()0H(错),末尾地址为24FFEH。第二片的首地址

为21001H,末尾地址为24FFFH。第三片的首地址为25000H,末尾地址为28F

FEHo第四片的首地址为25001H,末尾地址为28FFFH。

3.9第一片A19~A12=O1000000,地址范围是40000H~40FFEH

第二片A|9〜A>2=01000000,地址范围是40001H-40FFFH

第三片Ai9~Ai2=01000001,地址范围是410OOH-41FFEH

第四片A|9~A,2=01000001,地址范围是41001H-41FFFH

3.10(有问题A0和BHE未画)按现有的连线地址为

第一片A"~A13=1000000,地址范围是80000H〜81FFFH_

第二片人19~八13=1000001,地址范围是82023H-83FFFH一

An-A,

8086脸

AwAo

CPUAu

CE2716(4)

OEDs'Dis

WR

RD

D0~D7

D8'D15

图3-1RCR6cpiI与存储黑1车将由雅图

第三片A19〜A13=1000010,地址范围是84000H~85FFFH_

第四片Ai9〜Ai3=1000011,地址范围是860OOH~87FFFH_

A12~AO

A|9

A|7G

-

I译

61

IO/M-玛

IG

C2B甥

AHA<i

8086AMBA12,Ao

CPU:;:A

6264(1)

A|JCSCS6264(4)

__

WRWEWE

RD

OEDO~DT而Db-D,

D|f~D|5

DQ~D?

图3-28086CPU与存储器连接电路图

3.111)答:是译码功能。

2).

Au-A|

MWG

A|9

G-

A)8-译

_BA

G-码

CPUA"-器

c

8086A:B

A|4A

BHE

WR

RD

n皿

3)答:ROM。、ROM1的地址范围。94000H-97FFFH

3.12答:存储器⑴的地址范围为80000H-80FFEH;存储器⑵的地址范围

为80001H〜80FFFH。(题目有错,存储器(4)的地址范围为81001H~81FFFH)

3.13答:1)系统的存储容量为:B3FFFH-B0000H+1=4000H=16KB;

2)需要6264芯片:(16K*8bit)/8K*8bit=2片;

3)画出系统连接图。两片6264芯片的地址范围如表所示,高位地址

A14-A19参与译码形成两片6264的片选信号,奇地址存储器芯片和偶地

址存储器芯片由A0和丽石区分。存储器与系统总线的连接电路如图题3.13

所示。

AAlAlAA1AAAAA

A19A18A13AllA10A8A7A5A4A2

176514296310

00000000000000

11111111111111

A13~A|

A19G

入H

--

M/IOG2A译

--

A|8G2B器Y4A|2A()A12…Ao

CPUC

A[6B-------WEWE

A15A-------OE6264(1)OE6264(2)

A14

cJ-CS2CS2

RD

CS1CS1

WRD0...D?D0...D7

BHE.

Ao

DO~D7

D8~D[5

图题3.13存储器扩展电路

3.14答:(不是8086系统)

RD

WR

DLDT

3.15在8086CPU组成的系统中,用4片2764(8Kx8bit)存储芯片组成随机

ROM存储系统,其第一片的首地址为(C000H:8000H),试画出存储器与CPU的连接电路

图。

A|3~A|

A|9G

A珏

G

M/IO-译

-码

5器

CPUC

B

A

BHE

D|)~D'

Da-Dr

第四章8086/8088指令系跳

4.1答:机器语言的每一条指令是以二进制为代码的指令,它可以被计算机直

接执行。汇编语言是用助记符或用符号来编写指令,是一种与机器语言一一相应的

语言。机器不能直接执行程序,程序必须通过翻译,机器才干执行。高级语言是面向

过程的语言,它不依赖于特定的机器,独立于机器,用同一种高级语言编写的程序可以

在不同的机器上运营而获得相同的结果。

4.2请指出以下各指令的源、目的操作数所使用的寻址方式。

(1)MOVSL2100H源:立即数寻址;目:寄存器寻址

(2)SBBBYTEPTRDISP[BXJ,7;源:立即数寻址:目:寄存器相对寻址

(3)AND»[DI],AX源:寄存器寻址;目:寄存器间接寻址

(4)ORAX,[609EH]源:直接寻址;目:寄存器寻址

(5)MOV[BX+DI+30H],CX源:寄存器寻址;目:基址变址相对寻址

(6)PUSHES:[BP]源:寄存器间接寻址;目:隐含寻址

(7)CALL|DI]DISP寄存器相对寻址

(8)JNZShort_1abe1直接寻址

(9)CBWBL(指令错)

(10)MOVAX,[1000H]源:直接寻址;目:寄存器寻址

(11)MOVAX,ARRAY[BX][SI];源:基址变址相对寻址;目:寄存器寻址

(12)MULBL源:寄存器寻址;目:隐含寻址

(13)MOVAX,[BX][Sil源:基址变址寻址;目:寄存器寻址

(14)MOVAL,TABLE源:直接寻址;目:寄存器寻址

(15)MOVAX,DISP[BX+DI]源:基址变址相对寻址;目:寄存器寻址

(16)MOVAX,[BX]源:寄存器间接寻址;目:寄存器寻址

4.3答:基址寄存器BX、基址指针寄存器BP、原变址寄存器SI、目的变址寄

存器DL

4.4下列各条指令是否有错?假如有,请指犯错误之处。

(1)MOVoDS,1000H立即数不能直接给段寄存器送数

(2)MOV[100],23H目的操作数应指明类型,改为BYTEPTR

noo]

(3)ADDAX,[BX+BP+6]存储器寻址不能有两个基地址fBX,B

PI

(4)PUSH»DL进栈是以字为单位

(5)INAX,[3FH]I/O接口地址不能加括号

(6)OUT»3FFH,AL口地址3FF应放在DX中

(7)LESSS,[SI]SS不能存放偏移量

(8)POP[AX]AX不用来做间址寄存器

(9)IMUL4CH乘法中源操作数不能是立即数

(10)SHL»BX,5移位超过1位应放在CL中

(11)INT300。立即数(向量码)应小

于255

(12)XCHGDX,0FFFH此指令中不能有立即数

(13)POPAL出栈是以字为单位

(14)DIV32H除法中原操作数不能是立

即数

(15)MOVAX,BYTEPTR[SI]源操作数和目的操作数不等宽

(16)MOVDX,DS:[BPJ对的

(17)MOV128,CL目的操作数不能为立即数

4.5设若标志寄存器原值为0A11H,SP=0060H,AL=4。下列几条指令

执行后,标志寄存器、AX、SP的值分别是多少?

PUSHF;F-*SP;SP=5EH,[5EH]=0Al1

H

LAHF;F低8fAHAH=11H

XCHGAH,ALAH04H,AL=11H

PUSHAXSP=5CH,[5CH]=0411H,

SAHF;AH—F低8

POPFSPfF

标志寄存器=。411H,AX=O411H,SP=OO5EH

4.6已知DS=2023H,有关的内存单元值为:(21000H)=00H,(21001

H)=12H,(21200H)=00H,(21201H)=1OH,(23200H)=20H,(23201H)=30H,

(23400H)=40H,(23401H)=30H,(23600H)=60H,(23601H)=30H,符号COUN

T的偏移地址为1200H。执行下列指令后,寄存器AX、BX、SI的值分别是

多少?

MOVBX,OFFSETCOUNTBX=120OH

MOVSL[BX]SI=100OH

MOVoAX,COUNTfSI][BX]

AX=3040H.BX120OHSI=JOOOH

4.7答:AX=322FH,标志寄存器值为0410H

4.8设单元DATA在内存数据段中的偏移量为24C0H,在24coH〜24c3H

单元中依次存放着55H、66H、77H、88H。下列几条指令执行后,寄存器A

X、BX、CL、SI、DS的值分别是多少?

MOVAX,DATA;AX=6655H

LEAoSLDATA;SI=24C0H

MOVCL,ISI|;CL=55H

LDSoBX,DATA:DS=8877H,BX=6655H

4.9若AX=26D3H,CX=7908H,CF=1,0F=0,执行下列指令后,寄存器AX、

CX的值分别是多少?AX=A74cHCX=FA08HCF=0OF=0。

SAL»CH,1CH=FA,CL=A8II

RCR»AX,CLAX=A726H.CF=1

ROLAL,1AL=4CH,CF=0

4.10答:原串在数据段中,但可以段超越。目的串必须在附加段中。

4.11答:M/万=1;DT/斤=1;而=1;而=0;

数据总线上的数是0508H;地址总线上的数分是49420H

4.12(与21题函)答:AL=23H,功能将压缩的BCD码转换为二进制。

4.13答:上述程序段执行后,字节单元HCOD的内容是43H;HCOD+1的

内容是35H。该程序段的功能是将压缩的十六进制转换为ASCII字符。

4.14执行下面的程序段后.(CL)=02H.(AX)=0040H。

XORBX,BX

MOVAX,001OH

MOVCL,2

SALAL,CL

MOVBL,AL

SALAL,CL

ADDAX,BX

4.15问:(1)初值(AL)=37H时.程序段执行结果:(AL)=07H

(2)初值(AL)=9FH时,程序段执行结果:(AL)=0FFH

4.16下列程序段中,以X为首址的字单元中的数据依次为1234H、5678H;

以Y为首址的字单元中的数据依次为8765H、4321H。阅读程序,给出必要的程

序注释并完毕程序后的问题。

LEASI,X;SI=00OOH

LEADI,Y;D1=0004H

MOV°DX,[SI+2];DX=5678H

MOVoAX,XAX=1234H

ADDAX,X;AX=2468H

ADODX,[SI+2];DX=ACF0H

CMPDX,[DI+2];ACF0H与8765H比

JLoL2;小于转移到L2

CMPAX,Y;大于2468H与4321比

JL4J;小于转移到L1

JMPoEXIT;无条件转移到EXIT

LI:MOVoAX,1;给AX送1

JMPoEXIT;无条件转移到EXIT

L2:MOVoAX,2

EXIT:......

以上程序代码执行之后,AX=」_;DX=ACF0H

4.17答:程序将依次向堆栈压入的数据为0003H、0002H、OOOlHo该程

序段实现了将二进制转换十进制功能。

4.18答:程序功能是计算AX=1~1O,BX=1OH起的累加和。AX=10,BX=47H,C

X=0o

MOVAX,00OOH

MOVBX,001OH

MOVCX,10

LP:INCAX

ADDBX,AX

LOOPLP

HLT

4.19答:以上程序代码执行之后,AX=_2____;DX=ACF0H

4.20阅读下列程序段,给出必要的程序注释并完毕程序后的问题。

ADDAL,AL:2*AL

ADDAL、AL;4*AL

MOVBL,AL;AL-BL

SALBL,1;8*AL

ADDAL,BL:12*AL

HLT

(1)该程序段的功能是什么?答:把AL中的内容乘以12

(2)设AL的初值为0AH,执行该程序段后,AL为多少?答:AL=78H

4.21已知有程序段如下:(与12题重)

(1)该程序段的功能是什么?

答:将BCD码转换成二进制

(2)执行该程序段后,AL=23H

4.22、下列程序段规定在内存40000H开始的顺序30个单元中存放着8位无

符号数,将它们的和放在DX中,试填空完毕该程序(并加入必要的注释)或自行编

制一段程序完毕上述功能。

MOVAX,4000H;

MOVDS,AX;送段首地址

MOVSL0000H:送偏移量

MOVCX,30;送循环次数

XORAX,AX;清零

GOON:ADDALJSI1;两数相加

ADCAH,00H;加进位位

INCSI;修改地址

DECex;计数器减1

JNZGOON;不为零循环

MOVDX,AX;结果送DX

4.23在AL中有一个十六进制数的ASCII码,完毕下面程序段在每一空白处

填上一条适当指令(并加入必要的注释),实现将AL中的ASCII码转换成二进制

数。

CMPAL,3AH;与3AH比较_________

JCDONE:小于转移到DONE

SUBAL,7;大于减7

DONE:SUBAL,3OH;AL减30H

HLT

4.24已知附加段中有一块长50个字的数据区,首址为DEST。欲编程将

它们所有初始化为OFFFFH值,试在下面程序段的空白处填上适当的指令或操作

数(并加入必要的注释),以实现上述功能。

LEA—DI,DEST;取DEST偏移量

MOVCX,100;送计数值

CLD;清方向标志位,DF=0

MOVAL,0FFH;将AL-0FFH

REPSTOSB:将送100个字节FFH到首址为DES

T区域

4.25己知附加段中有一块长50个字的数据区,首址为DEST。欲编程将它

们所有初始化为0FFFFH值,试在下面程序段的空白处填上适当的指令或操作

数(并加入必要的注释),以实现上述功能。(与24题重)

DI,DEST;____________________________

MOV»CX,;______________________________

CLD;

MOVAL,0FFH;______________________________

4.26附加段中有某字符串首址为BLOCK,长17个字节。欲查找其中第一

次出现字符“e”的位置,并将该位置所在的偏移量入栈保护。试在下面程序段的

空白处填上适当的指令(并加入必要的注释)或操作数以实现上述功能。

MOV。DI,OFFSETBLOCK;送BLOCK的偏移量

MOV«AL,65H;送eASCII码

MOVoCX,17;送计数值

CLD;方向标志位清零

REPNZSCASB;寻找e

JNEoOTHER;找到e转到OTHER

DEODI;修改地址

PUSHDI;偏移量入栈保护

OTHER:.......(略)

4.27已知有某字串BUF1的首址为0000H,BUF2的首址为0010H,

数据段与附加段重合。欲从BUF1处开始将10个字数据顺序传送至BUF2处,

试在下面程序段的空白处填上适当的指令或操作数以实现上述功能。

LEASI,BUF1;送BUF1的偏移量

ADDSI,12H;地址移动到字符串最后

LEAoDI,BUF2;送BUF2的偏移量:

ADDDI,12H;地址移动到字符串最后

STD;方向标志位清零

MOVCX,10;送计数值

REPMOVSW;进行串操作

4.28在DAT和DATI两个字节变量单元中有两个十进制数的ASCII码,编程

实现将这两个ASCII码转换为两个BCD码,并以压缩形式存放在REST字节变量

单元中。试填写该程序划线部分,并加入必要的注释。

MOVAL,DAT;取第一个数

SUBAL,30H;将ASCH码转为BCD码

MOVCL,4;送移位数

SHLAL,CL;将BCD码放在AL高四位中

MOVBL,DAT1;取第二个数

SUBBL,30H将DAT1中的ASCII码转为BCD码

ORAL,BL:将两个BCD码合并在AL寄存器中

MOVREST,AL;将压缩形式的BCD码存入REST中

HLT

第五章汇编语言程序设计

5.1答:标号在指令性指令的名字,写在指令前面,标号后必须有冒号。变

量在伪指令前是定义某一数据区所起的名字,它后面不带冒号。标号和变量都有段、

偏移量的属性,标号的类型是远和近型,变量的类型是字节、字、双字等。

5.2答:指令性指令是给CPU的命令,它是由I|题5.3图

汇编程序翻译成机器语言指令,在程序运营时由CPU来执行,每条指令都相应CPU

一种特定的操作。伪指令不汇编成机器语言,仅仅在汇编过程中告诉汇编程序应如何

汇编。

5.3

答:ADD1、ADD2、ADD3的段基址为IOOOH;ADD1、偏移量为2023H、

类型为双字;ADD2、偏移量为2023H、类型为字节;ADD3、偏移量为2068H、

类型为字。

5.4

答:分派情况如右图

5.5答:(定义了堆栈段[81字节]、数据段(17字节)和代码段)

02H1006HADD1

12H

9AH1009HADD2

56H

42H

41H题5.4图

―0100H

05H

ADD1

05H

5.6答:ADD1占有多少个字节

0127H题5.6图

5.7答:1.依据设计任务,抽象出描述问题的数

学模型。2.拟定实现数学模型的算法或求解的具体环节和方法。3.绘制出程序

流程框图。4.分派存储空间及工作单元(涉及寄存器)。拟定数据段、堆栈段、代

码段及附加段在内存中的位置。5.依据流程图编写程序。6.静态检查。7.上

机调试。8.程序运营,结果分析。

5.8答:源程序结构一般涉及4个段,它们是代码段、数据段、附加段和堆

栈段。其中代码段是必须存在的,其余段视具体情况而定。

一般用到四种程序结构:顺序结构,分支结构,循环结构,子程序结构。

5.9答:XORAX,AX

MOVDX,0

MOVAH,45H

MOVDL,AH

ANDDL,0FH

ADDDL,3OH

ANDAH,0F0H

MOVoCL,4

SHRAH,CL

ADDDL,3OH

ADDAX,DX

HLT

94HyDATA1

16H

5.10答:MOVAL,A

26H

MOVBL,B89H

温馨提示

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

评论

0/150

提交评论