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)];
}
}
BCD码转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码
本回答被网友采纳BCD码转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码
本回答被网友采纳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 ;程序结束