您的位置 首页 被动

怎么使用片内RAM单元直接转化BCD 码与 BIN 数据

如何利用片内RAM单元直接转换BCD 码与 BIN 数据- 把二进制数转换成 BCD 码,是很常见的,做而论道以前也发表过这样的程序。 但是,过去都是用寄存器,如果要求用片内RAM单元,就少见了。 当然,也可以把片内RAM单元的数据,先传送到寄存器,再利用以前写的程序进行转换。转换完毕后,再把结果传送到片内RAM单元。 如果直接用片内RAM单元来进行转换呢? 这也是可以的,只是速度会慢一些。 以前,从来没有见过有谁编写出来直接使用片内RAM转换的程序。

把二进制数转化成 BCD 码,是很常见的,小编曾经也宣布过这样的程序。

可是,曩昔都是用寄存器,假如要求用片内RAM单元,就少见了。

当然,也能够把片内RAM单元的数据,先传送到寄存器,再使用曾经写的程序进行转化。转化结束后,再把成果传送到片内RAM单元。

假如直接用片内RAM单元来进行转化呢?

这也是能够的,仅仅速度会慢一些。

曾经,历来没有见过有谁编写出来直接运用片内RAM转化的程序。

没有人编写,大约便是速度的原因吧。

小编现在就编写一个,我们看看,和运用寄存器比较,速度有多少下降。

下面便是这样的标题。

怎么使用片内RAM单元直接转化BCD 码与 BIN 数据

编写一段程序,将存放于片内RAM 40H、41H单元中的 16 位二进制数转化为紧缩BCD码存放到 38H~3AH 中。

小编的答复如下:

;

TO_BCD:

MOV R2, #16 ;转化16位

CLR A

MOV 38H, A ;先清零

MOV 39H, A

MOV 3AH, A

LOOP:

MOV A, 41H ;取被转化二进制数

RLC A

MOV 41H, A

MOV A, 40H

RLC A ;最高位移动到C

MOV 40H, A

;———————

MOV A, 3AH ;取数

ADDC A, 3AH ;左移并加上C

DA A ;转为BCD码

MOV 3AH, A ;保存

MOV A, 39H

ADDC A, 39H

DA A

MOV 39H, A

MOV A, 38H

ADDC A, 38H

MOV 38H, A

DJNZ R2, LOOP ;循环16次

RET

本程序现已通过实验,确保正确。

===============================

下面,是别的一个问题,问的便是相反转化的问题。

这样的程序,小编曾经就编写出来,而且运用过很多年了。

仅仅在网上、书上,历来也没有见过这样的转化程序。

----

编写一段程序,将存放于片内 RAM 30H~32H 单元中的5位紧缩BCD数(小于65536)转化为二进制数存放到 40H、41H 单元中。

小编的答复如下:

TO_BIN:

MOV A, 32H

SWAP A

ANL A, #0FH ;得到十位数字

MOV B, #10

MUL AB

MOV B, 32H

ANL B, #0FH ;得到个位数字

ADD A, B

MOV 41H, A ;(41H)=十位*10+个位

;———————

MOV A, 31H

SWAP A

ANL A, #0FH ;得到千位数字

MOV B, #10

MUL AB

MOV B, 31H

ANL B, #0FH ;得到百位数字

ADD A, B ;(A)=千位*10+百位

MOV B, #100

MUL AB ;(B A)=千位*1000+百位*100

;———————

ADD A, 41H

MOV 41H, A

CLR A

ADDC A, B

MOV 40H, A ;(40H 41H)=千位*1000+百位*100+十位*10+个位

;———————

MOV A, #10H ;2710H=1万

MOV B, 30H ;万位

MUL AB

MOV R2, B

MOV R3, A

MOV A, #27H

MOV B, 30H ;万位

MUL AB

ADD A, R2

MOV R2, A ;R2 R3=万位*10000

;———————

MOV A, R3

ADD A, 41H

MOV 41H, A

MOV A, R2

ADDC A, 40H

MOV 40H, A

RET

本程序现已通过了实验验证,确保正确。

跋文:

针对这个问题,发问者采用了一个过错的程序。

这个过错程序,不只有错,长度还差不多到达本程序的两倍。

小编编写的程序,不只正确,基本上便是最精简的,我们能够比较看一下。

其实,小编还有更为精简的,仅仅才 35 行指令,能够说是世上最精练转化程序。仅仅技巧太高,不易了解,就不发布了。

用 C 言语编程,不太符合标题的要求。

可是,也有人编写的很好,收录在下面:

viod BcdHex(viod)

{

unsigned short int *OutAdd, *SrcAdd, x;

SrcAdd = 0x30;

OutAdd = 0x40;

*OutAdd = 0; x = 1;

*OutAdd += (SrcAdd[0] & 0x0F) * x; x *= 10;

*OutAdd += (SrcAdd[0] 》》 4) * x; x *= 10;

*OutAdd += (SrcAdd[1] & 0x0F) * x; x *= 10;

*OutAdd += (SrcAdd[1] 》》 4) * x; x *= 10;

*OutAdd += (SrcAdd[2] & 0x0F) * x;

}

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/ziliao/beidong/347770.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部