十六进制、BCD码和十进制的转换

在做嵌入式软件的设计中,经常会遇到十六进制、 BCD 码与十进制之间的转换,最近做 M1 卡的应用中,涉及了大量的十六进制、 BCD 码与十进制之间的转换。笔者通过对 BCD 码、十六进制 权的理解,轻松的实现了他们之间的互换。

#include <stdio.h>
#include <string.h>
 
/
//
// 功能:二进制取反
//
// 输入: const unsigned char *src  二进制数据
//      int length                待转换的二进制数据长度
//
// 输出: unsigned char *dst        取反后的二进制数据
//
// 返回: 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;
}
 
//
//
// 功能:十六进制转为十进制
//
// 输入: const unsigned char *hex          待转换的十六进制数据
//      int length                       十六进制数据长度
//
// 输出:
//
// 返回: int  rslt                        转换后的十进制数据
//
// 思路:十六进制每个字符位所表示的十进制数的范围是 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;
}
 
 
/
//
// 功能:十进制转十六进制
//
// 输入: int dec                     待转换的十进制数据
//      int length                  转换后的十六进制数据长度
//
// 输出: unsigned char *hex          转换后的十六进制数据
//
// 返回: 0    success
//
// 思路:原理同十六进制转十进制
//
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;
}
 
/
//
// 功能:求权
//
// 输入: int base                    进制基数
//      int times                   权级数
//
// 输出:
//
// 返回: unsigned long               当前数据位的权
//
//
unsigned long power(int base, int times)
{
    int i;
    unsigned long rslt = 1;
 
    for(i=0; i<times; i++)
        rslt *= base;
 
    return rslt;
}
 
/
//
// 功能: BCD 转 10 进制
//
// 输入: const unsigned char *bcd     待转换的 BCD 码
//      int length                   BCD 码数据长度
//
// 输出:
//
// 返回: unsigned long               当前数据位的权
//
// 思路:压缩 BCD 码一个字符所表示的十进制数据范围为 0 ~ 99, 进制为 100
//      先求每个字符所表示的十进制值,然后乘以权
//
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;
}
 
/
//
// 功能:十进制转 BCD 码
//
// 输入: int Dec                      待转换的十进制数据
//      int length                   BCD 码数据长度
//
// 输出: unsigned char *Bcd           转换后的 BCD 码
//
// 返回: 0  success
//
// 思路:原理同 BCD 码转十进制
//
//
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;
}
//------------- 函数信息 ------------------------------------------
// 函 数 名 : BCDtoDec
// 函数描述 : BCD 码转换成十进制码
// 入口参数 : temp: 转化的 BCD 码
// 返     回 : 转化后的十进制码
// 作     者 :
// 日     期 : 2006.11.24
// 说     明 :
//
//---------------------------------------------------------------
uint8  BCDtoDec( uint8 temp )
{
return ( ( temp/16 )*10+temp%16) ;
}
 
 
 
 
//------------- 函数信息 ------------------------------------------
// 函 数 名 : DectoBCD
// 函数描述 : 十 / 十六进制码转换成 BCD 码
// 入口参数 : temp: 转化的十进制码
// 返     回 : 转化后的 BCD 码
// 作     者 :
// 日     期 : 2006.11.24
// 说     明 :
//
//---------------------------------------------------------------
uint8 DectoBCD( uint8 temp )
{
return ( (temp/10)*16 + temp%10 ) ;
}

本文转载自:http://blog.csdn.net/lenyusun/article/details/5350143

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值