兰州理工大学微机原理习题集作业答案1-5章

更新时间:2024-06-14 10:40:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

微 机 原 理 及 应 用 B 作 业

第 一 章 微型计算机概论

1.1、答:微型计算机系统包括硬件系统和软件系统两大部分。硬件系统包括:微型计算机、外部设备、电源及其它辅助设备。软件系统包括:系统软件和应用软件。

微型计算机也称为主机,主机包括:微处理器、存储器、输入/输出接口(Input/Output),微处理器通过系统总线和存储器、输入/输出接口进行连接。

微处理器(Microprocessor Unit)简称为MPU(或者称为MP),它是一个中央控制器(Central Processing Unit),简称CPU。它是微型计算机的核心部件,它将运算器、控制器、寄存器通过内部总线连接在一起,并集成在一个独立芯片上。 1.2、答:单片机是将CPU、ROM、RAM以及I/O接口电路以及内部系统总线等全部集中在一块大规模集成电路芯片上,就构成了单片机。

单板机是将微处理器芯片、存储器芯片、I/O接口芯片及少量的输入输出设备(键盘,数码显示器)安装在一块印制板上构成一台微型计算机。

由多块印制板构成的微机称为多板机。 1.3、完成下列转换(保留4位小数)

(21.32)10=(10101.0101)2=(25.2436)8=(15.51EB)16 50.38D= 110010.0110 B=62.3024 Q= 32.6147 H 1.4、完成下列计算 已知X=-63,Y=59

则[X]原=BFH(10111111B),[X]反=C0H(110000000B),[X]补=C1H(11000001B) [Y]原=3BH(00111011B),[Y]反=3BH(00111011B),[Y]补=3BH(00111011B)

[X+Y]补=0FCH(11111100B), [X-Y]补=86H(10000110B)。 [X] 补+[Y]补=0FCH(11111100B),[X] 补-[g]补=86H(10000110B)。 1.5、答:浮点数是指小数点在数值中的位置不是固定不变,实际位置将随阶码而浮动,用这种方法表示的数,称为浮点数。

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

1

微 机 原 理 及 应 用 B 作 业

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

1.7、写出下列数值的压缩的BDC码、非压缩的BDC码、ASCΠ码值。 (改为15,29)

15=[15H]压缩BCD码= [0105 H] 非压缩BCD码= [3135 H] ASCΠ码

29= [29H]压缩BCD码= [0209H] 非压缩BCD码= [3239H] ASCΠ码

第 二 章 8086/8088 微处理器

2.1 答:从功能上讲由两部分组成 总线接口单元BIU和执行单元EU组成。 总线接口单元(BIU)是微处理器内部与存储器和I/O接口传送信息的通道,总线接口单元负责从内存中将指令送到指令队列中;负责把数据从内存或I/O接口送到执行单元(EU);负责将执行单元的运行结果送到内存或I/O接口。 EU的功能是负责译码和执行指令。

2.2 答:指令队列(Queue)存放预取的指令,采用预取指令的方法将减少微处理器的等待时间,提高运行效率。8086CPU中指令队列有6个;8088 CPU中指令队列有只有4个。

2.3 答:8086/8088 CPU中有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。另一类为控制标志,

2

微 机 原 理 及 应 用 B 作 业

用来控制CPU操作,反映存储器地址变化的方向、是否允许中断及在执行程序时是否进行单步中断。控制标志有3个:DF、IF和TF控制标志是人为设置的,每个控制标志都对某种特定的功能起控制作用。

2.5 答: 8086与8088有3点不同之处;1. 8086有16条数据线而8088只有8条数据线,2. 8086MN/MX而8088MN/MX。3. 8086M/IO而8088M/IO。

2.6 答:堆栈是在内存中开辟的一个特定的区域,用以存放CPU寄存器或存储器中暂时不用的数据和有用的信息。在数据段和附加段存放数据时,一般是从低地址开始向高地址存放数据,而用PUSH指令向堆栈中存放数据时总是从高地址开始逐渐向低地址方向增长。堆栈指令遵循“先进后出”,“后进先出”的原则,凡是用PUSH指令最后推入堆栈的数据,用POP指令弹出时最先出栈。在操作时是以字为单位。

2.7 答:8086/8088 CPU各有20根地址总线,可寻址范围是1M个存储单元。8086CPU有16根数据,一次可以读一个字也可以读一个字节。8088 CPU有8数据总线一次以读一个字节。

2.8 答:1.物理地址就是实际地址,它具有20位的地址值,它是唯一标志1MB存储空间的某一单元的地址。2.逻辑地址由段基址和偏移量组成。程序以逻辑地址编址,而不是物理地址。3.在8086/8088存储空间中,把16个字节的存储空间看作一节。为了简化操作,要求各个逻辑段从节的整数边界开始,也就是说段首地址低4位应该是“0”,因此把段首地址的高16位称为“段基值”。4. 偏移量是该物理地址距离段首地址的单元数。

2.9 答:总线上传输信号的一组导线,作为微机各部件之间信息传输的公共通道。系统总线按功能分数据总线、地址总线、控制总线。

2.10答:1.8086/8088 CPU把存储器分为代码段、数据段、堆栈段、附加段。因为8086/8088的寄存器是16位,最大只能寻址64K个单元的存储空间,为了增大寻址空间把存储器进行分段,这样就可以寻址1MB存储空间。2.每段最大空间为64KB。

2.11 答:(1)2300H;1010H;24010H (2) 0000H;1000H;01000H (3)2AE0H;1690H;2C490H (4) 7369H;0010H;736A0H

2.12 答:1.数据段首地址是12000H末地址是21FFFH。2.附加段的首地址是20A30H末地址是30A2FH。3.代码段的首地址是470E0H=470EH×10H末地址是570DFH=(470E0H+FFFFH)。

2.13答:8086/8088 CPU复位以后,除代码段寄存器外,其余标志寄存器、指令指针寄存器、各段寄存器及指令对列全部被清零。

2.14答:在一个读总线周期ALE在第一个时钟周期为高电平,其余周期为低电平。BHE/S7在第一个时钟周期为低电平,其余周期为高电平。RD在第一个时钟周期为低电平,第二、三周期为高电平。WR一直为高电平。M/IO一直为高电平。DT/R一直为低电平。

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

状态的前沿(下降沿)对Ready信号进行采样。若CPU在T3状态的开始采样到Ready信号为低电平,那么将在T3和T4之间插入等待状态TW。3.TW可以是一个,也可以是多个。CPU在每个TW的前沿处对Ready信号进行采样。当在TW状态采样到

3

微 机 原 理 及 应 用 B 作 业

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

第 三 章 存 储 器

3.1 答:1.容量:存储器芯片的容量是以1位二进制数(bit)为单位,因此存储器容量是指每一个存储器芯片所能存储的二进制数的位数。(存储器容量=存储单元数?位数)芯片数量(N)?系统容量 2.存储速度:存储器的基本操作是读出与写入,

芯片容量称为“访问”或“存取”。存储器的存储速度有两个时间参数:(1)访问时间(Access Time) TA 从启动一次存储器操作,到完成该操作所经历的时间。 (2)存储周期(Memory Cycle) TMc 启动两次独立的存储器操作之间所需的最小时间间隔。3.存储器的可靠性:4.性能/价格比:5.其他指标(存储器的选择有时还应考虑功耗、集成度等指标)。 3.2答:按存储器的读写功能分可以分为随机读写存储器(RAM)和只读存储器(ROM)。随机读写存储器RAM可以随机地按指定地址从存储单元存入或读取(简称存取)数据,存放在RAM中的信息,一旦掉电就会丢失。

随机读写存储器RAM可分为静态随机存取存储器SRAM、动态随机存取存储器DRAM和集成随机读写存储器IRAM。

只读存储器(ROM)的基本特征是在正常运行中只能随机读取预先存入的信息,即使在断电情况下,ROM仍能长期保存信息内容不变,所以它是一种永久存储器。

只读存储器(ROM)可分为掩膜只读存储器(Mask ROM)、可编程只读存锗器(PROM)、

2

紫外线可擦除可编程只读存储器(EPROM)、电可擦除编程只读存储器(EPROM)和快速可擦编成只读存储器(Flash EPROM)。

掩膜只读存储器其结构简单,存储信息稳定,可靠性高,能够永久性保存信息;可编程只读存储器是由半导体厂家制作“空白”存储器阵列(即所有存储单元全部为1或全部为0状态)出售,用户根据需要可以实现现场编程写入,但只能实现一次编程;紫外线可擦编程只读存储器、电可擦除编程只读存储器和快可擦编程只读存储器等不仅可以现场编程。还可以擦除原存储的信息内容,写入新的信息。

3.3 答:SRAM的特点是在一个存储单元所用晶体管数目多,但不需要刷新电路。DRAM的特点是在一个存储单元所用晶体管数目少,但需要刷新电路。IRAM的特点是将动态随机存取存储器和刷新电路集成在一片芯片中,它即具有SRAM速度快的优点,又具有DRAM的廉价。IRAM实际上是附有刷新电路的 DRAM。它在现代微机系统中得到广泛应用,大容量的内存一般都是用IRAM。

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

3)17条地址线和4条数据线;4)15条地址线和8条数据线 3.5 答:1)RAM的存储容量为256K×8 bit;2)有18条地址线和8条数据线;3)若采用6116需要128片,若采用6264需要32片,若采用62128需要16片,若采用2114需要512片,若采用2141需要512片。

3.6 答:1)ROM的存储容量为512K×8 bit;2)需要19条地址线和8条数据线;3)若采用2764需要64片,若采用27128需要32片,若采用2816A需要256片,若采用28F256需要16片。

4

微 机 原 理 及 应 用 B 作 业

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

线选法地址线可以不用完,也无需专门的译码电路。但由于高位地址线可随意取值0或1。所以,存在地址重叠,并且造成存储器地址不能连续分布。

全译码法所有地址线均参加地址译码,芯片的地址线直接和低位地址总线相连,高位地址总线经译码器或逻辑电路与各芯片的片选信号相连。

部分译码法与全译码法类似,只是高位地址线中有一部分进行译码,产生片选信号,而不是全部。这种方法称为部分译码法。

3.8 答:第一片的首地址为21000H(错),末尾地址为24FFEH。第二片的首地址为21001H,末尾地址为24FFFH。第三片的首地址为25000H,末尾地址为28FFEH。第四片的首地址为25001H,末尾地址为28FFFH。

3.9第一片 A19~A12=01000000,地址范围是 40000H~40FFEH 第二片 A19~A12=01000000,地址范围是40001H~40FFFH 第三片 A19~A12=01000001,地址范围是 41000H~41FFEH 第四片 A19~A12=01000001,地址范围是 41001H~41FFFH 3.10 (有问题A0和BHE未画)按现有的连线地址为

第一片 A19~A13=1000000,地址范围是 80000H~81FFFH__ 第二片 A19~A13=1000001,地址范围是 82000H~83FFFH__ 第三片 A19~A13=1000010,地址范围是 84000H~85FFFH__

A11~A1A18A19G≥G2A译译G2B译CBAY1≥≥8086CPUA16IO/MA15A14A13A12A0BHE…A10…A0CE6116(1)WROED0~D7A10…A0CE6116(2)WROED8~D15A10…A0CE2716(3)A10…A0CE2716(4)Y0≥≥OED0~D7OED8~D15WRRDD0~D7D8~D15 图3-1 8086CPU与存储器连接电路图 第四片 A19~A13=1000011,地址范围是 86000H~87FFFH__

5

微 机 原 理 及 应 用 B 作 业

A12~A0AA19GYA17318GIO/M≥2A译Y28086A码GY116AC2B器A12…A012…A0A12…A0A12…A0CPUAA15BA14AY013CS6264(1)CS6264(2)CS6264(3)CS6264(4)WRWEWEWEWERDOED0~D7OED0~D7OED0~D7OED0~D7D8~D15D0~D7 图3-2 8086CPU与存储器连接电路图 3.11 1)答:是译码功能。 2).

A13~A1Y5M/IOA≥19&GY4A≥18G2A译Y3A17G≥CPU2B码Y2A12?A0A12?A0A12?A0A12?A08086A器A16C15Y1≥ARAM014BY0CS6264CSRAM16264CSROM02764CSROM12764AA0BHERDRDWRD0~D7WRD0~D7RDD0~D7RDD0~D7 WRRDD0~D7D8~D15 3)答:ROM0、ROM1的地址范围。94000H~97FFFH

3.12答:存储器(1)的地址范围为80000H~80FFEH;存储器(2)的地址范围为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和BHE区分。存储器与系统总线的连接电路如图题3.13所示。

A19 A18 A17 A16 A15 A14 A13 A12 A11 A10 A9 A8 A7 A6 A5 A4 A3 A21 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1

0

1

1

0

0

1

1

1

1

1

1

1

1

1

1

1

1

6

A1 A00 0 1

1

微 机 原 理 及 应 用 B 作 业

A13~A1A19A17M/IO&GG2A译码Y4G2B器CBA+5V≥1CPUA18A16A15A14RDWRA12…A0WEOE6264(1)CS2CS1D0…D7≥1A12…A0WEOE6264(2)CS2CS1D0…D7BHEA0D0~D7D8~D15

图题3.13 存储器扩展电路

3.14答:(不是8086系统)

A10~A0A11M/IOA19G≥G2A译码G2B器CBAY3Y4Y2Y1Y0≥CPUA16A15A14A13A12A0~A10CS6116RDWRD0…D7≥A0~A10CS6116RDWRD0…D7≥A0~A10CS6116RDWRY0…DD0~D37≥A…0~A10A9CS6116RDWRD0…D7A0~A10CS2732RDD0…D7…A0~A10CS2732RDD0…D7A0~A10CS2732RDD0…D7RDWRD0~D7

3.15在8086CPU组成的系统中,用4片2764(8K×8 bit)存储芯片组成随机ROM存储系统,其第一片的首地址为(C000H:8000H),试画出存储器与CPU的连接电路图。

A13~A1A19A18M/IO&GY3A12…A0WE2764(1)CSD0…D7≥1CPUA17A16A15A14RDG2A译码Y2G2B器CBA≥1A12…A0WE2764(2)CSD0…D7≥1A12…A0WE2764(3)CSA12…A0WE2764(4)CSD0…D7≥1D0…D7答:BHEA0D0~D7D8~D15

第 四 章 8086/8088指令系统

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

7

微 机 原 理 及 应 用 B 作 业

接执行。汇编语言是用助记符或用符号来编写指令,是一种与机器语言一一对应的语言。机器不能直接执行程序,程序必须经过翻译,机器才能执行。高级语言是面向过程的语言,它不依赖于特定的机器,独立于机器,用同一种高级语言编写的程序可以在不同的机器上运行而获得相同的结果。

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

(1)MOV SI,2100H 源:立即数寻址;目:寄存器寻址 (2)SBB BYTE PTR DISP[BX],7;源:立即数寻址;目:寄存器相对寻址 (3)AND [DI],AX 源:寄存器寻址;目:寄存器间接寻址 (4)OR AX,[609EH] 源:直接寻址;目:寄存器寻址

(5)MOV [BX+DI+30H],CX 源:寄存器寻址;目:基址变址相对寻址 (6)PUSH ES:[BP] 源:寄存器间接寻址;目:隐含寻址 (7)CALL [DI]DISP 寄存器相对寻址 (8)JNZ Short_ label 直接寻址 (9)CBW BL (指令错)

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

(11)MOV AX, ARRAY [BX][SI];源:基址变址相对寻址;目:寄存器寻址 (12)MUL BL 源:寄存器寻址;目: 隐含寻址 (13)MOV AX, [BX][SI] 源:基址变址寻址;目:寄存器寻址 (14)MOV AL,TABLE 源: 直接寻址;目:寄存器寻址

(15)MOV AX,DISP[BX+DI] 源:基址变址相对寻址;目:寄存器寻址 (16)MOV AX,[BX] 源:寄存器间接寻址;目:寄存器寻址

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

4.4下列各条指令是否有错?如果有,请指出错误之处。 (1) MOV DS,1000H 立即数不能直接给段寄存器送数

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

(3)ADD AX,[BX+BP+6] 存储器寻址不能有两个基地址[BX,BP] (4)PUSH DL 进栈是以字为单位 (5)IN AX,[3FH] I/O接口地址不能加括号 (6)OUT 3FFH,AL 口地址3FF应放在DX中 (7)LES SS,[SI] SS不能存放偏移量 (8)POP [AX] AX不用来做间址寄存器 (9)IMUL 4CH 乘法中源操作数不能是立即数 (10)SHL BX,5 移位超过1位应放在CL中 (11)INT 300 立即数(向量码)应小于255 (12)XCHG DX,0FFFH 此指令中不能有立即数 (13)POP AL 出栈是以字为单位

(14)DIV 32H 除法中原操作数不能是立即数 (15)MOV AX,BYTE PTR[SI] 源操作数和目的操作数不等宽 (16)MOV DX,DS:[BP] 正确

8

微 机 原 理 及 应 用 B 作 业

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

4.5设若标志寄存器原值为0A11H,SP=0060H,AL=4。下列几条指令执行后,标志寄存器、AX、SP的值分别是多少?

PUSHF ;F→SP ; SP=5EH , [5EH]=0A11H LAHF ;F低8→AH ; AH=11H XCHG AH,AL ; AH 04H , AL=11H PUSH AX ; SP=5CH , [5CH]=0411H, SAHF ;AH→F低8 ; POPF ; SP→F

标志寄存器=0411H,AX= 0411H,SP=005EH

4.6已知DS=2000H,有关的内存单元值为:(21000H)=00H,(21001H)=12H,(21200H)=00H,(21201H)=10H,(23200H)=20H,(23201H)=30H,(23400H)=40H,(23401H)=30H,(23600H)=60H,(23601H)=30H,符号COUNT的偏移地址为1200H。执行下列指令后,寄存器AX、BX、SI的值分别是多少?

MOV BX,OFFSET COUNT BX=1200H MOV SI,[BX] SI=1000H MOV AX,COUNT[SI][BX] AX=_3040H__,BX = _1200H__,SI=__1000H____ 4.7答:AX=322FH , 标志寄存器值为0410H

4.8设单元DATA在内存数据段中的偏移量为24C0H,在24C0H~24C3H单元中依次存放着55H、66H、77H、88H。下列几条指令执行后,寄存器AX、BX、CL、SI、DS的值分别是多少?

MOV AX,DATA ; AX=6655H LEA SI,DATA ; SI=24C0H MOV CL,[SI] ; CL=55H LDS BX,DATA ; DS=8877H,BX=6655H

4.9若AX=26D3H,CX=7908H,CF=1,OF=0,执行下列指令后,寄存器AX、CX的值分别是多少?_ AX=A74CH ___ CX=FA08H __CF=_0__OF=__0_。

SAL CH,1 CH=FA,CL=08H RCR AX,CL AX=A726H , CF=1 ROL AL,1 AL=4CH , CF=0 4.10答:原串在数据段中,但可以段超越。目的串必须在附加段中。 4.11答: M/IO=1;DT/R=1;RD=1;WR=0; 数据总线上的数是0508H;地址总线上的数分是49420H

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

4.13 答:上述程序段执行后,字节单元HCOD的内容是43H;HCOD+1的内容是35H。该程序段的功能是将压缩的十六进制转换为ASCII字符。

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

MOV AX, 0010H

9

微 机 原 理 及 应 用 B 作 业

MOV CL, 2 SAL AL , CL MOV BL , AL SAL AL , CL

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

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

4.16下列程序段中,以X为首址的字单元中的数据依次为1234H、5678H;以Y为首址的字单元中的数据依次为8765H、4321H。阅读程序,给出必要的程序注释并完成程序后的问题。

LEA SI,X ;SI=0000H LEA DI,Y ; DI=0004H MOV DX,[SI+2] ; DX=5678H MOV AX,X ; AX=1234H ADD AX,X ; AX=2468H ADC DX,[SI+2] ; DX=ACF0H

CMP DX,[DI+2] ; ACF0H与8765H比 JL L2 ;小于转移到L2

CMP AX,Y ;大于2468H与4321比 JL L1 ;小于转移到L1 JMP EXIT ;无条件转移到EXIT L1:MOV AX,1 ;给AX送1

JMP EXIT ;无条件转移到EXIT L2:MOV AX,2 EXIT:…… 以上程序代码执行之后,AX= 2 ;DX= ACF0H

4.17答:程序将依次向堆栈压入的数据为0003H、0002H、0001H。该程序段实现了将二进制转换十进制功能。

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

MOV AX , 0000H MOV BX , 0010H MOV CX ,10 LP: INC AX

ADD BX , AX LOOP LP HLT

4.19答:以上程序代码执行之后,AX= 2 ;DX= ACF0H 4.20阅读下列程序段,给出必要的程序注释并完成程序后的问题。

10

微 机 原 理 及 应 用 B 作 业

ADD AL,AL ;2*AL ADD AL、AL ;4*AL MOV BL,AL ;AL→BL SAL BL,1 ;8*AL ADD AL,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中,试填空完成该程序(并加入必要的注释)或自行编制一段程序完成上述功能。

MOV AX,4000H ; MOV DS,AX ; 送段首地址 MOV SI,0000H ; 送偏移量 MOV CX, 30 ; 送循环次数 XOR AX,AX ; 清零 GOON: ADD AL, [SI] ; 两数相加 ADC AH,00H ; 加进位位 INC SI ; 修改地址 DEC CX ; 计数器减1 JNZ GOON ; 不为零循环

MOV DX ,AX ; 结果送DX 4.23在AL中有一个十六进制数的ASCII码,完成下面程序段在每一空白处填上一条适当指令(并加入必要的注释),实现将AL中的ASCII码转换成二进制数。

CMP AL,3AH ; 与3AH 比较 JC DONE ; 小于转移到DONE SUB AL,7 ; 大于减7 DONE:SUB AL,30H ; AL减30H HLT

4.24已知附加段中有一块长50个字的数据区,首址为DEST。欲编程将它们全部初始化为0FFFFH值,试在下面程序段的空白处填上适当的指令或操作数(并加入必要的注释),以实现上述功能。

LEA MOV

DI,DEST ; 取DEST偏移量

CX, 100 ; 送计数值

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

11

微 机 原 理 及 应 用 B 作 业

MOV

AL,0FFH ; 将AL←0FFH REP STOSB ; 将送100个字节FFH到首址为DEST区域 4.25已知附加段中有一块长50个字的数据区,首址为DEST。欲编程将它们全部初始化为0FFFFH值,试在下面程序段的空白处填上适当的指令或操作数(并加入必要的注释),以实现上述功能。(与24题重)

DI,DEST ; MOV CX, ; CLD ; MOV AL,0FFH ; ; 4.26附加段中有某字符串首址为BLOCK,长17个字节。欲查找其中第一次出现字符“e”的位置,并将该位置所在的偏移量入栈保护。试在下面程序段的空白处填上适当的指令(并加入必要的注释)或操作数以实现上述功能。

MOV DI, OFFSET BLOCK ; 送BLOCK 的偏移量 MOV AL, 65H ; 送eASCII码 MOV CX, 17 ; 送计数值

CLD ; 方向标志位清零 REPNZ SCASB ; 寻找e JNE OTHER ; 找到e转到OTHER DEC DI ; 修改地址 PUSH DI ; 偏移量入栈保护 OTHER:……(略)

4.27已知有某字串BUF1的首址为0000H,BUF2的首址为0010H,数据段与附加段重合。欲从BUF1处开始将10个字数据顺序传送至BUF2处,试在下面程序段的空白处填上适当的指令或操作数以实现上述功能。

LEA SI,BUF1 ; 送BUF1的偏移量 ADD SI, 12H ; 地址移动到字符串最后 LEA DI,BUF2 ; 送BUF2的偏移量 ADD DI, 12H ; 地址移动到字符串最后 STD ; 方向标志位清零 MOV CX, 10 ; 送计数值 REP MOVSW ; 进行串操作 4.28在DAT和DAT1两个字节变量单元中有两个十进制数的ASCII码,编程实现将这两个ASCII码转换为两个BCD码,并以压缩形式存放在REST字节变量单元中。试填写该程序划线部分,并加入必要的注释。

MOV AL,DAT ;取第一个数

SUB AL,30H ;将ASCII码转为BCD码 MOV CL,4 ; 送移位数 SHL AL,CL ;将BCD码放在AL高四位中

12

微 机 原 理 及 应 用 B 作 业

MOV BL,DAT1 ;取第二个数

SUB BL,30H ;将DAT1中的ASCII码转为BCD码 OR AL,BL ;将两个BCD码合并在AL寄存器中 MOV REST,AL ;将压缩形式的BCD码存人REST中 HLT

第 五 章 汇编语言程序设计

5.1 答:标号在指令性指令的名字,写在指令前面,标号后必须有冒号。变量在伪指令前是定义某一数据区所起的名字,它后面不带冒号。标号和变量都有段、偏移量的属性,标号的类型是远和近型,变量的类型是字节、字、双字等。

5.2 答:指令性指令是给CPU的命令,它是由

07H ←0100H ADD1

汇编程序翻译成机器语言指令,在程序运行时由CPU

00H

来执行,每条指令都对应CPU一种特定的操作。伪

00H

指令不汇编成机器语言,仅仅在汇编过程中告诉汇编

00H

程序应如何汇编。

01H

5.3 答:ADD1、ADD2、ADD3的段基址为1000H;00H

00H ADD1、偏移量为2000H、类型为双字;ADD2、

00H 偏移量为2018H、类型为字节;ADD3、偏移量为

2068H、类型为字。

…… 5.4

01H 2018H ADD2 答:分配情况如右图

04H 5.5答:(定义了堆栈段[81字节]、数据段(17

05H 字节)和代码段)

…… 02H 12H 9AH 56H 42H 41H

1006H ADD1

1009H ADD2 题5.4图

05H 05H 05H 07H 01H …… …… 05H 05H

2068H ADD3 题5.3图

←0100H ADD1

13

微 机 原 理 及 应 用 B 作 业

5.6答:ADD1占有多少个字节 5.7答: 1.依据设计任务,抽象出描述问题的数 学模型。2.确定实现数学模型的算法或求解的具体 …… 步骤和方法。3.绘制出程序流程框图。 4.分配存05 储空间及工作单元(包括寄存器)。确定数据段、堆 栈段、代码段及附加段在内存中的位置。 5.依 0127H题5.6图 据流程图编写程序。6.静态检查。7.上机调试。8.程序运行,结果分析。

5.8 答: 源程序结构一般包括4个段,它们是代码段、数据段、附加段和堆栈段。其中代码段是必须存在的,其余段视具体情况而定。

一般用到四种程序结构:顺序结构,分支结构,循环结构,子程序结构。 5.9 答: XOR AX, AX MOV DX , 0

MOV AH,45H MOV DL,AH AND DL,0FH ADD DL, 30H AND AH,0F0H MOV CL,4 SHR AH,CL ADD DL, 30H ADD AX,DX HLT

5.10 答: MOV AL , A MOV BL , B

…… IMUL BL

94H ← DATA1

MOV CX , C

16H

ADD AX , CX

26H

SUB AX , 18

89H

HLT

30H ← DATA2

(1)从DATA1单元开始,将8个组合BCD

55H 码累加起来,其和(超过1字节)存入以RES

为首址的单元中(低位在前)。 04H

74H 图5-1 5.11题图

← RES …… (2)将它们看作2个分别以DATA1、DATA2

为首址的4位十进制数(低位在前),求此两数

之差并存入以RES为首址的单元中。

答: 1、 LEA SI , DATA1 2、LEA SI , DATA1 LEA DI , DATA2 LEA DI , DATA2 LEA BX , RES LEA BX , RES

14

微 机 原 理 及 应 用 B 作 业

MOV CX ,7 XOR AX , AX

XOR AX , AX MOV AX , WORD PTR [SI] MOV AL , BYTE PTR [SI] ADD AX , WORD PTR [DI] AA1:INC SI MOV DX , WORD PTR [SI+2] ADD AL , BYTE PTR [SI] ADC DX , WORD PTR [DI+2] ADC AH , 0 MOV WORD PTR [BX] , AX LOOP AA1 MOV WORD PTR [DI+2] , DX MOV WORD PTR [BX] , AX HLT HLT

5.12 答:根据各种条件判断和比较进行操作,满足条件去做一种操作,不满足条件去做另一种操作。每一种操作程序称为一个分支,一次判断产生两个分支,只有一次判断的称为单重分支程序。多次判断产生多个分支,称为多重分支程序。

5.13 答:MOV AL,DAT AND AL,DAT

JNS POSI ;若为正数转POS1 TEST AL,01H ;测试负数的奇偶性 JZ M ;若为负偶数转M

OR AL,BUF ;若为负奇数进行‘或’运算

JMP DONE

M:XOR AL,BUF ;负偶数进行‘异或’运算 JMP DONE

POSI:TEST AL,01H ;判断正数的奇偶性

JZ N ;为正偶数,转N

ADD AL,BUF ;为正奇数进行‘加’运算 JMP DONE

N:AND AL,BUF ;正偶数进行‘与’运算 DONE:MOV BUF,AL

HLT

5.14 答:实现的方法仍是两两进行比较判断。其步骤是:先取出X,Y,Z,假设

15

本文来源:https://www.bwwdw.com/article/tvu6.html

Top