资源描述
第四章 习题与参考答案
4.1 程序设计语言有哪三种?各有什么异同?汇编语言有哪两类语言?各有什么特点?
4.2 在汇编语言程序设计中,为什么要采用标号来表达地址?标号的构成原则是什么?使用标号有什么限制?注释段起什么作用?
4.3 MCS-51汇编语言有哪几条常用伪指令?各起什么作用?
4.4 汇编语言程序设计分哪几步?各环节的任务是什么?
4.5 汇编语言源程序的机器汇编过程是什么?第二次汇编的任务是什么?
4.6 请用除法指令编写例4.2的程序,并计算所占内存字节数和所需机器周期数。
4.7 设内部RAM 20H 单元有两个非零的BCD数,请编写求两个BCD数的积并把积送入21H单元的程序。
4.8 已知,从内部RAM BLOCK单元开始存放有一组带符号数,数的个数存放在LED单元。请编写可以记录其中正数和负数个数并分别存入NUM和NUM+1单元的程序。
4.9 设自变量X为一无符号数,存放在内部RAM的VAX单元,函数Y存放在FUNC单元。请编写满足如下关系的程序:
X>=50时:Y=X;
50>X>=20时:Y=5X;
X<20时:Y=2X;
4.10 在例4.6的128分支程序中,若用LJMP指令代替AJMP指令,以便分支程序可以放在64KB地址范围的任务位置。请修改原程序,修改后的程序最多可实现多少个分支?
4.11 从外部RAM的SOUCE(二进制8位)开始有一数据块,该数据块以$字符结尾。请编写程序,把它们传送到以内部RAM的DIST为起始地址的区域($字符也要传送)。
4.12 在例4.11中,若SOUCE为二进制16位,则程序又该如何编。
4.13 在外部RAM的低256地址单元区,有起始地址为SOUCE且长度存放在LEN单元的数据块。请编写能对它们进行奇偶校验的程序。凡满足奇校验(奇数个1)的数据均送到内部RAM起始地址为DIST的存储区。
4.14 在例4.13中,若SOUCE的地址不在外部RAM的滴56地址区,则程序该如何编写。
4.15 外部RAM从2023H到2100H有一数据块,请编写将它们传送到从3000H到3100H区域的程序。
4.16 设有一起始地址为FIRST+1的数据块,存放在内部RAM单元,数据块长度存放在FIRST单元并且不为0,规定记录该数据块中正偶数和负奇数的个数,并将它们分别存放在PAPE单元和NAOE单元。试画出能实现上述规定的程序流程图并编写相应程序。
4.17 请编写能从以内部RAM的BLOCK为起始地址的100个无符号数中找出最小值并把它送入MIN单元的程序。
4.18 已知,在内部RAM中,共有6组无符号4字节被加数和加数分别存放在以FIRST和SUCOND为起始地址的区域(低字节在前,高字节在后)。请编程序和(设和也为4字节),并把和存于以SUM开始的区域。
4.19 在内部RAM中,有一个以BLOCK为起始地址的数据块,块长存放在LEN单元。请用查表指令编写程序,先检查它们是否十六进制数中的A~F,若是十六进制数中的A~F,则把它们变为ASCII码;若不是,则把它们变为00H。
4.20 设在片内RAM的20H单元中有一数,其值范围为0~100,规定运用查表法求此数的平方值并把结果存入片外RAM的20H和21H单元(20H单元中为低字节),试编写相应程序。
4.21 在内部RAM中,从BLOCK开始的存储区有10个单字节十进制数(每字节有2个BCD数),请编程序求BCD数之和(和为3位BCD数),并把它们存于SUM和SUM+1单元(低字节在SUM单元)。
4.22 在例4.21中,若改为10个双字节十进制数求和(和为4位BCD数),结果仍存于从SUM开始的连续单元(低字节先存)。请修改相应程序。
4.23 已知MDA和MDB内分别存有两个小于10的整数,请用查表子程序实现c=a 2+2ab+b 2 ,并把和存于MDC和MDC+1单元(MDC中放低字节)。
4.24 已知外部RAM起始地址为STR的数据块中有一以回车符CR断尾的十六进制ASCII码。请编写程序,将它们变为二进制代码,放在起始地址为BDATA的内部RAM存储区中。
4.25 设晶振频率为6MHZ,试编写能延时20ms的子程序。
4.26 已知内部RAM的MA(被减数)和MB(减数)中分别有两个带符号数。请编写减法子程序,并把差存入RESULT和RESULT+1(低8位在RESULT单元)中。
4.27 设R0内为一补码形式的带符号被除数,R1内为补码形式的带符号除数,请通过编程完毕除法,并把商置于R2内且余数置于R3内。
4.28 设8031单片机外部RAM从1000H单元开始存放有100个无符号8位二进制数。规定编写子程序,能把它们从大到小依次存入片内从10H开始的RAM存储区,请画程序流程图。
解:
ORG 0030H
MOV R0,#10H
MOV R2,100
MOV DPTR,#1000H
MOV A,#00H
LOOP:MOVX A,@DPTR
MOV @R0,A
INC A
INC DPTR
DJNZ R2,LOOP
LOOP1: MOV R0,#10H ;置数据块指针R0
MOV R2,#100 ;块长送R2
CLR F0 ;互换标志F0清零
DEC R2 ;块长-1为比较次数
LOOP2: MOV 08H,@R0 ;第一个数送08H
INC R0
MOV A,@R0 ;第二个数送A
MOV 09H,A ;第二个数送A
CJNE A,08H,LOOP3 ;(11H)和(10H)作比较
LOOP3: JC LOOP4 ;若(09H)<(08H),则BUNEXT
MOV @R0,08H ;若(09H)>=(08H),则两者互换
DEC R0
MOV @R0,09H
INC R0 ;恢复地址块指针
SETB 7FH ;互换标志位置1
LOOP4: DJNZ R2,LOOP2 ;若一次冒泡未完毕,则BULOOP
JB F0,LOOP1 ;互换标志位1,则BUBBLE
SJMP $ ;结束
END
展开阅读全文