首页 > 编程知识 正文

bcd转换成十进制的代码讲解,bcd转换成十进制原理

时间:2023-05-03 23:40:49 阅读:203431 作者:4918

BCD码是指用二进制来表示十进制数的编码,即用4位二进制来表示一位十进制数,因此4位二进制数表示最大的十进制数9(1001),只取十六个数中的十个数(有别于8421码)。
为了表示两个十进制数(十位、个位),需要两个BCD码(8位),可以用char 类型来储存,比如:
BCD码:0x99 (153),共八位,储存在char 类型中,它对应的二进制为1001 1001.
该BCD码要转换成十进制数99。

思路:十进制数逢十进一,而十六进制逢十六进一,它们之间每次进位差了6,这就是十六进制与十进制数的本质区别,因此要把一个BCD转换成一个十进制的数,先要算清多进位了几次,比如0x99,它多进位9次,那它就多加了9次6,要转换成十进制,只需用0x99 - 9*6 即可。

所以,我比较中意的算法就是
153 - 99= 54
54 / 9 = 6

static unsigned char bcd_decimal(unsigned char bcd){return bcd-(bcd >> 4)*6;}static unsigned char decimal_bcd(unsigned char decimal){return (unsigned char) (decimal+(decimal / 10)*6);}

当然,方法不只一种,以下代码也可以实现:

int BCDToInt(byte bcd) //BCD转十进制{ return (0xff & (bcd>>4))*10 +(0xf & bcd);}int IntToBCD(byte int) //十进制转BCD{return ((int/10)<<4+((int%10)&0x0f);}

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。