一、BCD码
1.简介
BCD码(Binary-Coded Decimal),也称为二-十进制代码,是一种将十进制数转换为二进制数的编码方式,用4位二进制数来表示1位十进制数中的0~9这10个数码。BCD码使用四个位Bit来储存一个十进制的数码,使二进制和十进制之间的转换转换变得非常快捷和简单。
2.分类
BCD码可分为有权码和无权码两类。其中,常见的有权BCD码有8421码、2421码、5421码,无权BCD码有余3码、余3循环码、格雷码。8421BCD码是最基本和最常用的BCD码,它和四位自然二进制码相似,各位的权值为8、4、2、1,故称为有权BCD码。
例如,十进制的12,对应8421格式BCD码是0001 0010,即8*0+4*0+2*0+1*1=1,8*0+4*0+2*1+1*0=2,合起来是12,而原BCD码看上去像是十六进制的0x12。
常用的BCD码见下表:
十进制 | 8421 BCD | 5421 BCD | 2421 BCD | 余3 BCD |
---|---|---|---|---|
0 | 0000 | 0000 | 0000 | 0011 |
1 | 0001 | 0001 | 0001 | 0100 |
2 | 0010 | 0010 | 0010 | 0101 |
3 | 0011 | 0011 | 0011 | 0110 |
4 | 0100 | 0100 | 0100 | 0111 |
5 | 0101 | 1000 | 1011 | 1000 |
6 | 0110 | 1001 | 1100 | 1001 |
7 | 0111 | 1010 | 1101 | 1010 |
8 | 1000 | 1011 | 1110 | 1011 |
9 | 1001 | 1100 | 1111 | 1100 |
二、进制转换
转换方法比较简单,本文只讨论8421格式的BCD码的转换,且只在2位十进制数范围内。
1.十进制数转BCD码
将2位十进制数的十位和个位分别取出,再进行转换,代码如下:
/*******************************************************************************
* 函数名:DecToBCD
* 功 能:十进制数转BCD码
* 参 数:dec:输入的十进制数
* 返回值:转换的BCD码
* 说 明:2位十进制数
*******************************************************************************/
uint8_t DecToBCD(uint8_t dec)
{
return ((dec / 10) << 4) + (dec % 10);
}
2.BCD码转十进制数
与十进制转BCD码过程相反,将BCD码的高4位和低4位分别取出,并转换:
/*******************************************************************************
* 函数名:BCDToDec
* 功 能:BCD码转十进制数
* 参 数:bcd:输入的BCD码
* 返回值:转换的十进制数
* 说 明:2位十进制数
*******************************************************************************/
uint8_t BCDToDec(uint8_t bcd)
{
return ((bcd >> 4) * 10 + (bcd & 0x0F));
}