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码


#include <stdio.h>
#include <stdlib.h>
#include <string.h>


/*
* 字符串转成bcd码,这个是正好偶数个数据的时候,如果是奇数个数据则分左靠还是右靠压缩BCD码
*/
int asc_to_bcd(char * dest,const char *src)
{
	unsigned char temp;
	while(*src !='\0')
	{
		temp = *src;
		*dest |= ((temp&0xf)<<4);
		src++;
		temp = *src;
		*dest |= (temp&0xf);
		src++;
		dest++;
	}
	return 0;
}

int asc_to_bcd_right(char *dest,const char *src,int src_len)
{
	unsigned char temp;
	if((src_len %2) !=0)
	{
		*dest &= 0;
		temp = *src;
		*dest |= (temp&0xf);
		src++;
		dest++;
	}
	asc_to_bcd(dest,src);
	return 0;
}

int asc_to_bcd_left(char *dest,const char *src,int src_len)
{
	unsigned char temp;
	if((src_len %2) !=0)
	{
		dest[src_len-1] &=0;
	}
	asc_to_bcd(dest,src);
	return 0;
}

void print_hex(char * bcd,int len)
{
	int i=0;
	for(i=0;i<len;i++)
	{
		int n = 8;
		while(n--){
			if((bcd[i] & (0x1<<n))==0)
				printf("0");
			else
				printf("1");
		}
		putchar('\n');
	}
}


int bcd_to_asc(char *dest,const char *src,int src_len)
{
	unsigned char temp;
	char *t = dest;
	while(src_len--)
	{
		*t |= ((*src&0xf0)>>4);
		*t++ |= 0x30;
		*t |= (*src&0xf);
		*t++ |= 0x30;
		src++;
	}
	return 0;
}

int left_bcd_to_asc(char *dest,const char * src,int src_len)
{
	bcd_to_asc(dest,src,src_len);
	dest[src_len*2 -1] = '\0';

	return 0;
}


int right_bcd_to_asc(char *dest,const char * src,int src_len)
{
	bcd_to_asc(dest,src,src_len);

	memmove(dest,dest+1,src_len*2-1);
	dest[src_len*2-1] = '\0';
	return 0;
}


int main(void)
{
	char str[100];
	
	char *str1 = "1234567";
	int str_len = strlen(str1);
	int bcd_len = (str_len+1)/2;
	char *bcd = (char *)malloc(bcd_len);
	printf("str_len = %d \n",str_len);
	printf("bcd_len = %d \n",bcd_len);
	memset(bcd,0,bcd_len);
	memset(str,0,100);

#if 0
	printf("右靠\n");
	asc_to_bcd_right(bcd,str1,str_len);
	print_hex(bcd,bcd_len);
	right_bcd_to_asc(str,bcd,bcd_len);
	printf("str = %s\n",str);
#endif

#if 1
	printf("左靠\n");
	asc_to_bcd_left(bcd,str1,str_len);
	print_hex(bcd,bcd_len);
	//memset(str,0,100);
	left_bcd_to_asc(str,bcd,bcd_len);
	printf("str = %s\n",str);
#endif
	return 0;
}





评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值