在做嵌入式軟件的設(shè)計中,經(jīng)常會遇到十六進制、BCD碼與十進制之間的轉(zhuǎn)換,最近做M1卡的應(yīng)用中,涉及了大量的十六進制、BCD碼與十進制之間的轉(zhuǎn)換。筆者通過對BCD碼、十六進制 權(quán)的理解,輕松的實現(xiàn)了他們之間的互換。
#include <stdio.h>
#include <string.h>
/////////////////////////////////////////////////////
//
//功能:二進制取反
//
//輸入:const unsigned char *src 二進制數(shù)據(jù)
// int length 待轉(zhuǎn)換的二進制數(shù)據(jù)長度
//
//輸出:unsigned char *dst 取反后的二進制數(shù)據(jù)
//
//返回:0 success
//
//////////////////////////////////////////////////////
int convert(unsigned char *dst, const unsigned char *src, int length)
{
int i;
for(i=0; i<length; i++)
{
dst[i] = src[i]^0xFF;
}
return 0;
}
//////////////////////////////////////////////////////////
//
//功能:十六進制轉(zhuǎn)為十進制
//
//輸入:const unsigned char *hex 待轉(zhuǎn)換的十六進制數(shù)據(jù)
// int length 十六進制數(shù)據(jù)長度
//
//輸出:
//
//返回:int rslt 轉(zhuǎn)換后的十進制數(shù)據(jù)
//
//思路:十六進制每個字符位所表示的十進制數(shù)的范圍是0 ~255,進制為256
// 左移8位(<<8)等價乘以256
//
/////////////////////////////////////////////////////////
unsigned long HextoDec(const unsigned char *hex, int length)
{
int i;
unsigned long rslt = 0;
for(i=0; i<length; i++)
{
rslt += (unsigned long)(hex[i])<<(8*(length-1-i));
}
return rslt;
}
/////////////////////////////////////////////////////////
//
//功能:十進制轉(zhuǎn)十六進制
//
//輸入:int dec 待轉(zhuǎn)換的十進制數(shù)據(jù)
// int length 轉(zhuǎn)換后的十六進制數(shù)據(jù)長度
//
//輸出:unsigned char *hex 轉(zhuǎn)換后的十六進制數(shù)據(jù)
//
//返回:0 success
//
//思路:原理同十六進制轉(zhuǎn)十進制
//////////////////////////////////////////////////////////
int DectoHex(int dec, unsigned char *hex, int length)
{
int i;
for(i=length-1; i>=0; i--)
{
hex[i] = (dec%256)&0xFF;
dec /= 256;
}
return 0;
}
/////////////////////////////////////////////////////////
//
//功能:求權(quán)
//
//輸入:int base 進制基數(shù)
// int times 權(quán)級數(shù)
//
//輸出:
//
//返回:unsigned long 當(dāng)前數(shù)據(jù)位的權(quán)
//
//////////////////////////////////////////////////////////
unsigned long power(int base, int times)
{
int i;
unsigned long rslt = 1;
for(i=0; i<times; i++)
rslt *= base;
return rslt;
}
/////////////////////////////////////////////////////////
//
//功能:BCD轉(zhuǎn)10進制
//
//輸入:const unsigned char *bcd 待轉(zhuǎn)換的BCD碼
// int length BCD碼數(shù)據(jù)長度
//
//輸出:
//
//返回:unsigned long 當(dāng)前數(shù)據(jù)位的權(quán)
//
//思路:壓縮BCD碼一個字符所表示的十進制數(shù)據(jù)范圍為0 ~ 99,進制為100
// 先求每個字符所表示的十進制值,然后乘以權(quán)
//////////////////////////////////////////////////////////
unsigned long BCDtoDec(const unsigned char *bcd, int length)
{
int i, tmp;
unsigned long dec = 0;
for(i=0; i<length; i++)
{
tmp = ((bcd[i]>>4)&0x0F)*10 + (bcd[i]&0x0F);
dec += tmp * power(100, length-1-i);
}
return dec;
}
/////////////////////////////////////////////////////////
//
//功能:十進制轉(zhuǎn)BCD碼
//
//輸入:int Dec 待轉(zhuǎn)換的十進制數(shù)據(jù)
// int length BCD碼數(shù)據(jù)長度
//
//輸出:unsigned char *Bcd 轉(zhuǎn)換后的BCD碼
//
//返回:0 success
//
//思路:原理同BCD碼轉(zhuǎn)十進制
//
//////////////////////////////////////////////////////////
int DectoBCD(int Dec, unsigned char *Bcd, int length)
{
int i;
int temp;
for(i=length-1; i>=0; i--)
{
temp = Dec%100;
Bcd[i] = ((temp/10)<<4) + ((temp%10) & 0x0F);
Dec /= 100;
}
return 0;
}
int main()
{
register int i;
unsigned char tmp_bff[12] = "";
//十六進制轉(zhuǎn)十進制
unsigned char HEX[4] = {0x34, 0xFE, 0x3E, 0xFF};
unsigned long dec_hex = 0;
dec_hex = HextoDec(HEX, 4);
printf("dec_hex = %d\n", dec_hex);
//十進制轉(zhuǎn)十六進制
DectoHex(dec_hex, tmp_bff, 4);
for(i=0; i<5; i++)
{
printf("tmp_bff[%d] = 0x%02X\n",i, tmp_bff[i]);
}
//BCD碼轉(zhuǎn)十進制
unsigned long dec_bcd = 0;
unsigned char BCD[4] = {0x98, 0x23, 0x45, 0x78};
dec_bcd = BCDtoDec(BCD, 4);
printf("dec_bcd = %d\n", dec_bcd);
//十進制轉(zhuǎn)BCD碼
DectoBCD(dec_bcd, tmp_bff, 4);
for(i=0; i<5; i++)
{
printf("tmp_bff[%d] = 0x%02X\n", i, tmp_bff[i]);
}
getchar();
}