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
当然,方法不只一种,以下代码也可以实现:
int BCDToInt(byte bcd) //BCD转十进制{ return (0xff & (bcd>>4))*10 +(0xf & bcd);}int IntToBCD(byte int) //十进制转BCD{return ((int/10)<<4+((int%10)&0x0f);}