您当前的位置:五五电子网电子知识电工技术电工基础bcd码转换成十进制程序 正文
bcd码转换成十进制程序

bcd码转换成十进制程序

点击数:7620 次   录入时间:03-04 11:46:43   整理:http://www.55dianzi.com   电工基础

在做嵌入式软件的设计中,经常会遇到十六进制、 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;

[1] [2]  下一页


本文关键字:程序  十进制  电工基础电工技术 - 电工基础