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;
- }
- int main()
- {
- register int i;
- unsigned char tmp_bff[12] = "";
- //十六进制转十进制
- 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);
- //十进制转十六进制
- DectoHex(dec_hex, tmp_bff, 4);
- for(i=0; i<5; i++)
- {
- printf("tmp_bff[%d] = 0x%02X/n",i, tmp_bff[i]);
- }
- //BCD码转十进制
- 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);
- //十进制转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();
- }
BCD码、十六进制与十进制互转的更多相关文章
- C# 进制转换(二进制、十六进制、十进制互转)
原文地址:https://www.cnblogs.com/icebutterfly/p/8884023.html C# 进制转换(二进制.十六进制.十进制互转)由于二进制数在C#中无法直接表示,所以所 ...
- C# 进制转换(二进制、十六进制、十进制互转) 转载 https://www.cnblogs.com/icebutterfly/p/8884023.html
C# 进制转换(二进制.十六进制.十进制互转)由于二进制数在C#中无法直接表示,所以所有二进制数都用一个字符串来表示例如: 二进制: 1010 表示为 字符串:"1010" int ...
- [No000071]C# 进制转换(二进制、十六进制、十进制互转)
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- 汇编_压缩BCD码和非压缩BCD码
BCD码是表示十进制数的,非压缩BCD码是用8位表示的,其实只用低4位,高4位全为0. 例如,十进制数36,用非压缩BCD码表示为:0000 0011 0000 0110 ,这是两个字节. 压缩BCD ...
- FPGA中将十进制数在数码管中显示(verilog版)--二进制转换为BCD码
这周有朋友问怎样在fpga中用数码管来显示一个十进制数,比如1000.每个数码管上显示一位十进制数.如果用高级语言来分离各位,只需要分别对该数做1000,100,10对应的取商和取余即可分离出千百十个 ...
- BCD码与16进制互转算法
关于这类算法,以前的文章已经讲过类似的:BCD码转二进制 #include <stdio.h> // HEX转BCD //bcd_data(<0x255,>0) unsigne ...
- BCD码转十进制C语言实现
#include <stdio.h> #include <stdlib.h> #define uchar unsigned char uchar BCD_Decimal(uch ...
- 二进制 转换成十进制 BCD码(加3移位法)
"原来的二进制数十几位,则左移时就要左移几位" "二进制数调整BCD码的方法是将二进制码左移8次,每次移位后都检查低四位LSD+3是否大于7,如是则加3,否则不加,高4位 ...
- BCD码转换为十进制或者十进制转为BCD码
BCD码其实就是之前在数字电路中说的 用4位二进制数值 来表示一个0-9中的数字,例如: 0000=0 0001=1 0010=2 0011=3也就是说如果把一个数字作为一个BCD码,例如: 11 2 ...
随机推荐
- 【多线程】--生产者消费者模式--synchronized版本
在实现生产者消费者模式之前,我们先了解一下线程的5种状态:被创建.运行.冻结.消亡.阻塞,如下图: 在Jdk1.5发布之前,我们实现生产者消费者模式一般使用synchronized + while循环 ...
- LinqToXML~读XML文件
linq的出现,带给我们的是简结,快速,可读性,它由linq to sql,linq to object,linq to XML组成,我的博客之前有对linq to sql的讲解,而今天,我将讲一个l ...
- 格而知之16:我所理解的Block(2)
11.那么Block到底是怎么实现的呢?试一试通过将Block 的代码转换成普通C语言代码来查看它的实现过程. 要将OC代码转换成C语言代码,可以使用clang编译的一个命令: 通过这个命令能把指定文 ...
- 创建一个jQuery UI的垂直进度条效果
日期:2013-9-24 来源:GBin1.com 在线演示 缺省的jQuery UI只有水平的进度条效果,没有垂直的进度条效果,仅仅重新定义JQuery UI的CSS不能解决这个问题. 这里我们扩 ...
- html5lib-python doc
http://html5lib.readthedocs.org/en/latest/ By default, the document will be an xml.etree element ins ...
- Oracle优化技术
1.基本原理 Oracle的日志:Oracle中为了提高硬盘写的效率,採用内存中数据缓冲区来保存数据,等到一定量或一定时间后才写到磁盘(DBWR). 这个时候假如断电之类的故障发生,数据缓冲区的数据将 ...
- Juqery 中使用 ajax
从 test.js 载入 JSON 数据,附加参数,显示 JSON 数据中一个 name 字段数据. jQuery 代码: $.getJSON("test.js", { name: ...
- Python 线程(threading) 进程(multiprocessing)
*:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...
- C#代码启用事务锁Transaction进行一系列提交回滚操作
一.前言 因为很多人一般进行一系列相关数据库操作都是在存储过程里面,而且在存储过程用锁的写法也是很简单的,在这篇文章主要介绍一下C#后台代码用锁进行一系列事务操作,我建立一个简单的winform程序, ...
- (原)使用intel的ipp库计算卷积及相关
转载请注明出处: http://www.cnblogs.com/darkknightzh/p/5462631.html 参考网址: https://software.intel.com/zh-cn/n ...