BCD码

 BCD 码的英文是 Binary Code Decimal ,用缩写 BCD 表 示。二-十进制编码,是用二进制码表示十进制码,也称 BCD 码。用二进制码表示十进制码,如果用三位二进制码只有八个状态,是不够的。至少需要四位,因为四位二进制码有十六个状态,舍去其中的六个,即可构成许多许多种 BCD 码。只有有特色的几种得到了应用。

 


     在一些数字系统中,如电子计算机和数字式仪器中,往往采用二进制码表示十进制数。通常,把用一组四位二进制码来表示一位十进制数的编码方法称作二─十进制码,亦称 BCD码( Binary Code Decimal)。
    4位二进制码共有16种组合,可从中任取10种组合来表示0~9这10个数。根据不同的选取方法,可以编制出很多种 BCD码,如8421码,5421码,2421码,5211码和余3码。表Z1101列出了这几种 BCD码,其中的8421 BCD码最为常用。
    由于每一组4位二进制码只代表一位十进制数,因而 位十进制数就得用n组4位二进制码表示。
    例1110 把十进制数369.74编成8421 BCD码。
    解:
      
                      表Z1101 常用BCD编码表
8421码
5421码
2421码
5211码
余3码
0
0000
0000
0000
0000
0000
1
0001
0001
0001
0001
0100
2
0010
0010
0010
0100
0101
3
0011
0011
0011
0101
0110
4
0100
0100
0100
0111
0111
5
0101
1000
0101
1000
1000
6
0110
1001
0110
1001
1001
7
0111
1010
0111
1100
1010
8
1000
1011
1110
1101
1011
9
1001
1100
1111
1111
1100
8421
5421
2421
5211


 

BCD码:
  BCD(Binary Coded Decimal)是用二进制编码表示的十进制数(见表3.3),十进制数采用0~9十个数字,是人们最常用的。在计算机中,同一个数可以用两种BCD格式来表示:①压缩的BCD码 ②非压缩的BCD码

  压缩的BCD码:
  压缩的BCD码用4位二进制数表示一个十进制数位,整个十进制数用一串BCD码来表示。例如,十进制数59表示成压缩的BCD码为0101 1001,十进制数1946表示成压缩的BCD码为0001 1001 0100 0110。

  非压缩的BCD码:
  非压缩的BCD码用8位二进制数表示一个十进制数位,其中低4位是BCD码,高4位是0。例如,十进制数78表示成压缩的BCD码为0000 0111 0000 1000。

  从键盘输入数据时,计算机接收的是ASCII码,要将ASCII码表示的数转换成BCD码是很简单的,只要把ASCII码的高4位清零即可。

ASCII和BCD码
十进制数字 ASCII码            压缩BCD码             非压缩BCD码
0                0011 0000        0000                          0000 0000
1                0011 0001        0001                          0000 0001
2                0011 0010        0010                          0000 0010
3                0011 0011        0011                          0000 0011
4                0011 0100        0100                          0000 0100
5                0011 0101        0101                          0000 0101
6                0011 0110        0110                          0000 0110
7                0011 0111        0111                          0000 0111
8                0011 1000        1000                          0000 1000
9                0011 1001        1001                          0000 1001

void BcdToAscii (char *ascii_buf, const BYTE *bcd_buf, int len)
{
int i;
char ch;

for (i=0; i<len; i++)
{
  if (i & 1) ch = *(bcd_buf++) & 0x0f;
  else ch = *bcd_buf >> 4;
  ascii_buf[i] = ch + ((ch > 9)? 'A'-10 : '0');
}
}


一个BCD码占4位,而一个字节有8位。若把二个BCD码放在一个字节中,就叫压缩的BCD码。而一个字节只放一个BCD码,高位置0,则叫非压缩的BCD码。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值