BCD码转换成ASCII值
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BCD码转换成ASCII值相关的知识,希望对你有一定的参考价值。
我想问下各位大侠,压缩的BCD码要转换成两个ASCII值,应该怎么转换?我想知道转换的原理,请用文字给我描述下啊,直接上程序我看不明白。
voidWhAsciiToBcd(unsignedchar*psDataIn,size_tuiDataInLen,unsignedchar*psDataOut)
unsignedcharucTemp=0;
for(size_ti=0;i<uiDataInLen;i+=2)
ucTemp=psDataIn[i];
if(ucTemp>'9')
ucTemp=(unsignedchar)toupper((unsignedchar)ucTemp)-'A'+0x0A;
else
ucTemp&=0x0F;
psDataOut[i/2]=ucTemp<<4;
ucTemp=psDataIn[i+1];
if(ucTemp>'9')
ucTemp=(unsignedchar)toupper((unsignedchar)ucTemp)-'A'+0x0A;
else
ucTemp&=0x0F;
psDataOut[i/2]|=ucTemp;
扩展资料
ASCII转BCD
voidWhBcdToAscii(unsignedchar*psDataIn,size_tuiDataInLen,unsignedchar*psDataOut)
unsignedcharsAscii[]="0123456789ABCDEF";
for(size_ti=0;i<uiDataInLen;i++)
psDataOut[2*i]=sAscii[(psDataIn[i]>>4)];
psDataOut[2*i+1]=sAscii[(psDataIn[i]&0x0F)];
参考技术ABCD码转ASCII码:
BCD码表示:对于用BCD码怎么表示十进制数29上面已经分析的非常清楚了,这里不赘述了。十进制数29 === BCD码表示为:0010 1001
转换过程:可以直接转换。BCD码 0010 转换成ASCII码就直接加上 十六进制数0x30(十进制为48)就可以了,这个差值可以根据ASCII和十进制数换算下。同样的各位上的数也相加下就可以了。
C代码表示:#define BCD_TO_ASCCII(val) (((((val) >> 8) + 0x30) << 8) + (((val) & 0xFF) + 0x30))。
扩展资料:
BCD码可分为有权码和无权码两类:有权BCD码有8421码、2421码、5421码,其中8421码是最常用的;无权BCD码有余3码,余3循环码等。
8421 BCD码是最基本和最常用的BCD码,它和四位自然二进制码相似,各位的权值为8、4、2、1,故称为有权BCD码。
和四位自然二进制码不同的是,它只选用了四位二进制码中前10组代码,即用0000~1001分别代表它所对应的十进制数,余下的六组代码不用。
参考资料来源:百度百科-BCD码
参考技术BBCD码转ASCII码
BCD码表示:对于用BCD码怎么表示十进制数29上面已经分析的非常清楚了,这里不赘述了。十进制数29 === BCD码表示为:0010 1001
转换过程:可以直接转换。BCD码 0010 转换成ASCII码就直接加上 十六进制数0x30(十进制为48)就可以了,这个差值可以根据ASCII和十进制数换算下。同样的各位上的数也相加下就可以了。
C代码表示:#define BCD_TO_ASCCII(val) (((((val) >> 8) + 0x30) << 8) + (((val) & 0xFF) + 0x30))。
扩展资料
BCD码可分为有权码和无权码两类:有权BCD码有8421码、2421码、5421码,其中8421码是最常用的;无权BCD码有余3码,余3循环码等。
bcd码通常是指8421码就是将十进制的数以8421的形式展开成二进制,大家知道十进制是0~9十个数组成,这十个数每个数都有自己的8421码。
bcd码是四位二进制码, 也就是将十进制的数字转化为二进制, 但是和普通的转化有一点不同, 每一个十进制的数字0-9都对应着一个四位的二进制码,对应关系如下: 十进制0 对应 二进制0000 ;
十进制1 对应二进制0001 ....... 9 1001 ,接下来的10就有两个上述的码来表示 10,表示为00010000 也就是BCD码是遇见1001就产生进位,不象普通的二进制码,到1111才产生进位10000。
压缩BCD码与非压缩BCD码的区别—— 压缩BCD码的每一位用4位二进制表示,一个字节表示两位十进制数。例如10010110B表示十进制数96D;
非压缩BCD码用1个字节表示一位十进制数,高四位总是0000,低4位的0000~1001表示0~9.例如00001000B表示十进制数8。
参考资料:百度百科-BCD码
参考技术C bcd码通常是指8421码就是将十进制的数以8421的形式展开成二进制,大家知道十进制是0~9十个数组成,这十个数每个数都有自己的8421码bcd码是四位二进制码, 也就是将十进制的数字转化为二进制, 但是和普通的转化有一点不同, 每一个十进制的数字0-9都对应着一个四位的二进制码,对应关系如下: 十进制0 对应 二进制0000 ;十进制1 对应二进制0001 ....... 9 1001 接下来的10就有两个上述的码来表示 10 表示为00010000 也就是BCD码是遇见1001就产生进位,不象普通的二进制码,到1111才产生进位10000
压缩BCD码与非压缩BCD码的区别—— 压缩BCD码的每一位用4位二进制表示,一个字节表示两位十进制数。例如10010110B表示十进制数96D;非压缩BCD码用1个字节表示一位十进制数,高四位总是0000,低4位的0000~1001表示0~9.例如00001000B表示十进制数8.
百度百科http://baike.baidu.com/view/45179.htm?fr=ala0_1_1
BCD码代表数字0~9,ASCII码中也有代表数字0~9的码元,可以查看ASCII表,'0'=48,'1'=49,依次类推。
先把压缩BCD拆开变成非压缩BCD,然后加48就是ASCII中的0~9了!本回答被提问者采纳 参考技术D
8421BCD 码,加上 30H,即转换成了 ASCII 码。
压缩的BCD码,只要除以 16,即可分解成两个“非压缩的BCD码”。
然后,分别加上 30H 即可完成转换。
这么简单的事,如果动用 C 语言,就太累人了。
汇编语言的例程如下:
MOV A,#58H ;任取压缩的BCD码 00~99H
MOV B,#16
DIV AB ;分解完成
OR A,#30H ;分别加30H
OR B,#30H ;转换完毕
END ;程序结束
十进制数如何换算成8421BCD码
十进制数如何换算成8421BCD码
把一位十进制数,转换成二进制,再凑足四位,即可。
参考技术A十进制数换算成8421BCD码的方法如下:
1、十进制换算BCD码,整数从右边开始,每个数是4位二进制代码。比如:(195)10=(1 1001 0101)BCD,小数和其他进制转换不一样,是数位换算:(0.28)10=(0.0010 1000)BCD。
BCD码换算成十进制数的方法如下:
1、BCD码与十进制数的转换关系很直观,相互转换也很简单,将十进制数75.4转换为BCD码:7->0111,5->0101,4->0100所以拼成8421BCD码的结果是:(0111 0101.0100)BCD;若将BCD码1000 0101.0101转换为十进制数:1000->8,0101->5,0101->5所以结果是:(85.5)D。
二进制编码的十进制数,简称BCD码(Binarycoded Decimal)。
这种方法是用4位二进制码的组合代表十进制数的0,1,2,3,4,5,6 ,7,8,9 十个数符。4位二进制数码有16种组合,原则上可任选其中的10种作为代码,分别代表十进制中的0,1,2,3,4,5,6,7,8,9 这十个数符。最常用的BCD码称为8421BCD码,8.4.2.1 分别是4位二进数的位取值。
以上是关于BCD码转换成ASCII值的主要内容,如果未能解决你的问题,请参考以下文章