编程1:将存于内部RAM地址20H~25H的6位非压缩BCD码转换为对应的ASCII码依次存至30H开始的连续内部RAM单元中。
分析:非压缩BCD码00H、01H、02H、…、09H对应ASCII码30H、31H、32H、…、39H,两者差为30H;
程序如下:
LL: MOV R0,#20H;源数据串开始地址装入R0
MOV R1,#30H;目的数据串开始地址装入R1
MOV R2,#6;循环次数装入R2
L0:MOV A,@R0;取一字节非压缩BCD码
ORL A,30H;转化为对应ASCII码
MOV @R1,A;保存至对应目的位置
INC R0;修改源数据地址以指向下一位置
INC R1;修改目的数据地址指向下一位置
DJNZ R2,L0;循环进行下一字节的处理
RET;处理结束,程序返回
编程2:实现将0~49之间的偶数依次存于内部RAM地址20H开始的字节单元,将奇数依次存于内部RAM地址40H开始的字节单元。
程序如下:
LL: MOV R0,#20H;偶数存放开始地址装入R0
MOV R1,#40H;奇数存放开始地址装入R1
CLR A;起始数码=0
L0:MOV A,@R0;存放一个偶数
INC A;数码加1
MOV A,@R1;存放一个奇数
INC A;数码加1
INC R0;修改偶数存放地址指针指向下一位置
INC R1;修改奇数存放地址指针指向下一位置
CJNE A,#50,L0 ;是否所有数码都已放完,未完则继续循环
RET;工作完成,程序返回
编程3:实现5字节10位压缩BCD码加法。设两个加数分别存放于内部RAM地址40H和45H开始的字节单元(低位字节在前),相加结果存放于内部RAM地址4AH开始的字节单元,不考虑超出5字节压缩BCD码存储范围以外的进位。
程序如下:
LL: MOV R0,#40H;加数A的开始地址装入R0
MOV R1,#45H;加数B的开始地址装入R1
MOV R2,#4AH;和数存放开始地址装入R2
MOV R3,#5;循环次数装入R3
CLR C;初始清零CY
L0:MOV A,@R0;取加数A当前字节
ADDC A,@R1;加上加数B当前字节,通过带进位加法考虑低位字节可能的进位
AD A;调整运算结果为BCD码,可能的进位保存在CY中(以下的指令执行均不影响CY)
XCH A,R2;以下三条交换指令交换和数指针到R1,加数B指针到R2
XCH A,R1;
XCH A,R2;
MOV @R1,A;保存和数当前字节
XCH A,R2;以下三条交换指令恢复加数B指针到R1,和数指针到R2
XCH A,R1;
XCH A,R2;
INC R0;修改加数A存放地址指针指向下一位置
INC R1;修改加数B存放地址指针指向下一位置
INC R2;修改和数存放地址指针指向下一位置
DJNZ R3,L0;循环次数减1,若不为0则继续循环
RET;工作结束,程序返回