BCD码

压缩BCD码用4位2进制表示,1字节表示2位BCD码
如10010011B表示十进制数93
非压缩BCD码用1字节表示




BCD码是一一对应的,如:十进制的123 用BCD表示为:0001 0010 0011因为:十进制的 1 用二进制表示是 0001十进制的 2 用二进制表示是 0010十进制的 3 用二进制表示是 0011与二进制的区别:123的二进制应该用短除法求得1111011由此可见,BCD码只是机械地用二进制表示十进制的每一位。压缩与非压缩:由于1字节有8bit(8个0或1)如果用一字节存储4位BCD码(其余补0)就是非压缩如 十进制的123:00000001 00000010 0011如果用一字节存储8位BCD码就是压缩如 十进制的123:0001 0010 0011



4位BCD码 8421  8位BCD码 8421 8421 


C语言压缩bcd码


  1. #include <stdio.h>  
  2. #include <stdlib.h>  
  3. #include <string.h>  
  4.   
  5.   
  6. /* 
  7. * 字符串转成bcd码,这个是正好偶数个数据的时候,如果是奇数个数据则分左靠还是右靠压缩BCD码 
  8. */  
  9. int asc_to_bcd(char * dest,const char *src)  
  10. {  
  11.     unsigned char temp;  
  12.     while(*src !='\0')  
  13.     {  
  14.         temp = *src;  
  15.         *dest |= ((temp&0xf)<<4);  
  16.         src++;  
  17.         temp = *src;  
  18.         *dest |= (temp&0xf);  
  19.         src++;  
  20.         dest++;  
  21.     }  
  22.     return 0;  
  23. }  
  24.   
  25. int asc_to_bcd_right(char *dest,const char *src,int src_len)  
  26. {  
  27.     unsigned char temp;  
  28.     if((src_len %2) !=0)  
  29.     {  
  30.         *dest &= 0;  
  31.         temp = *src;  
  32.         *dest |= (temp&0xf);  
  33.         src++;  
  34.         dest++;  
  35.     }  
  36.     asc_to_bcd(dest,src);  
  37.     return 0;  
  38. }  
  39.   
  40. int asc_to_bcd_left(char *dest,const char *src,int src_len)  
  41. {  
  42.     unsigned char temp;  
  43.     if((src_len %2) !=0)  
  44.     {  
  45.         dest[src_len-1] &=0;  
  46.     }  
  47.     asc_to_bcd(dest,src);  
  48.     return 0;  
  49. }  
  50.   
  51. void print_hex(char * bcd,int len)  
  52. {  
  53.     int i=0;  
  54.     for(i=0;i<len;i++)  
  55.     {  
  56.         int n = 8;  
  57.         while(n--){  
  58.             if((bcd[i] & (0x1<<n))==0)  
  59.                 printf("0");  
  60.             else  
  61.                 printf("1");  
  62.         }  
  63.         putchar('\n');  
  64.     }  
  65. }  
  66.   
  67.   
  68. int bcd_to_asc(char *dest,const char *src,int src_len)  
  69. {  
  70.     unsigned char temp;  
  71.     char *t = dest;  
  72.     while(src_len--)  
  73.     {  
  74.         *t |= ((*src&0xf0)>>4);  
  75.         *t++ |= 0x30;  
  76.         *t |= (*src&0xf);  
  77.         *t++ |= 0x30;  
  78.         src++;  
  79.     }  
  80.     return 0;  
  81. }  
  82.   
  83. int left_bcd_to_asc(char *dest,const char * src,int src_len)  
  84. {  
  85.     bcd_to_asc(dest,src,src_len);  
  86.     dest[src_len*2 -1] = '\0';  
  87.   
  88.     return 0;  
  89. }  
  90.   
  91.   
  92. int right_bcd_to_asc(char *dest,const char * src,int src_len)  
  93. {  
  94.     bcd_to_asc(dest,src,src_len);  
  95.   
  96.     memmove(dest,dest+1,src_len*2-1);  
  97.     dest[src_len*2-1] = '\0';  
  98.     return 0;  
  99. }  
  100.   
  101.   
  102. int main(void)  
  103. {  
  104.     char str[100];  
  105.       
  106.     char *str1 = "1234567";  
  107.     int str_len = strlen(str1);  
  108.     int bcd_len = (str_len+1)/2;  
  109.     char *bcd = (char *)malloc(bcd_len);  
  110.     printf("str_len = %d \n",str_len);  
  111.     printf("bcd_len = %d \n",bcd_len);  
  112.     memset(bcd,0,bcd_len);  
  113.     memset(str,0,100);  
  114.   
  115. #if 0  
  116.     printf("右靠\n");  
  117.     asc_to_bcd_right(bcd,str1,str_len);  
  118.     print_hex(bcd,bcd_len);  
  119.     right_bcd_to_asc(str,bcd,bcd_len);  
  120.     printf("str = %s\n",str);  
  121. #endif  
  122.   
  123. #if 1  
  124.     printf("左靠\n");  
  125.     asc_to_bcd_left(bcd,str1,str_len);  
  126.     print_hex(bcd,bcd_len);  
  127.     //memset(str,0,100);  
  128.     left_bcd_to_asc(str,bcd,bcd_len);  
  129.     printf("str = %s\n",str);  
  130. #endif  
  131.     return 0;  

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值