压缩BCD码
⑴ 十进制数如何转换为压缩和非压缩bcd码
原是十进制的数的不用转就是BCD码,因BCD码的意就是十进制数码。压缩的就是在一个八位字节中放二位十进制数,这就要动一下了,把原放在二个字节中的二个单位的数,高位的先改放到字节的高四位中,再和低位的原就在低四位的或合到一起就成压缩的了。这样做的目的主要是为了节省存贮单元,可是在运算中要多用时间了。
⑵ 什么是压缩BCD码
压缩BCD码指二进制编码的十进制
压缩BCD码指一个字节8位存储2位BCD码。比如32用8421BCD码表示如下:非压缩BCD码表示:00000011 00000010;压缩BCD码表示:0011 0010;使用BCD码表示10进位制数字比较好理解,且占用空间较小,在用数字表示的数据方面得到广泛应用。如果听到“原长度10个字节,用压缩BCD码表示为5个字节”也就好理解了。比如“1234567890",即可以说用压缩BCD码表示为5个字节。
(2)压缩BCD码扩展阅读:
压缩BCD码的应用:BCD计数器也称为十进位计数器或模10计数器,它广泛地运用于各种电子设备中。特别是在测试仪表以及另外那些具有十进制输入与/或输出的设备中.运用得更普遍。数字计数器.万用表以及其它数字仪表,就是一类例子;数字电子表是另外一类例子。这与一个标准四位二进制计数器的前十个状态相同。不过,当计数器计9时,它循环回到0,然后它又重新开始递增计数。
⑶ 编程时什么是压缩BCD码 非压缩BCD码
压缩BCD码用4位2进制表示,1字节(8位2进制)表示2位BCD码,如10010011B表示十进制数93
非压缩BCD码用1字节表示,高4位总是0000,记住总是,低4位用0000--1001表示0--9,如93 表示为0000100100000011,占2个字节,00001001表示9,00000011表示3
⑷ BCD码中压缩和非压缩是怎么区别的
一、字节表示不同
1、非压缩BCD码:非压缩BCD码用1个字节表示一位十进制数。
2、压缩BCD码:压缩BCD码的每一位用4位二进制表示,一个字节表示两位十进制数。
二、内容规定不同
1、非压缩BCD码:高4位的内容不做规定(也有部分书籍要求为0,二者均可),低4位二进制表示该位十进制数。
2、压缩BCD码:每个数位占用半个字节(4个二进制位),其值也用二-->十进制编码(BCD码)或数字符的ASCII码的低4位表示。符号位也占用装修字节并放在最低数字位之后。其值选用四位编码中六种冗余状态中的有关值。
三、BCD码放置不同
1、非压缩BCD码:一个字节只放一个BCD码,高位置0。
2、压缩BCD码:把二个BCD码放在一个字节中。
⑸ 单片机压缩BCD码
比如说一个字节里是这么个二进制数: 01100010.
则这个字节的高四位0110是一个BCD码,表示十进制的6,
低四位0010是另外一个BCD码,表示十进制的2.
所以说一个字节里放了两个bcd码, 6和2,就是十进制的六十二.
把他们两个拆开,高四位的那个数乘十再加后面那个数,最后加上十六进制的0x30,就得到ASCII码了.
⑹ 怎样将压缩bcd码转换成非压缩bcd码
十进制数74转换为压缩BCD码是01110100b。所谓的压缩BCD码,指的就是用四位二进制数表示一位BCD码,用一个字节表示的两位BCD码,称为压缩型BCD码。一个BCD码占4位,而一个字节有8位。若把二个BCD码放在一个字节中,就叫压缩的BCD码。而一个字节只放一个BCD码,高位置0,则叫非压缩的BCD码。
⑺ 什么是压缩BCD码
可能我们在学校经常使用二进制和十六进制的数字表达形式。然而大多数情况下我们都是需要和十进制数进行转化来进行数字的表达,因为我们社会普遍习惯使用十进制。相对于一般的浮点式记数法,采用BCD码,既可保存数值的精确度,又可免去使计算机作浮点运算时所耗费的时间。
(一) 那么是什么BCD码呢?
BCD码(Binary-Coded Decimal),用4位二进制数来表示1位十进制中的0~9这10个数码,是一种二进制的数字编码形式,用二进制编码的十进制代码。
(二)如何用bcd码表示十进制数?
首先,如果我们想表达0~9这几个数字,那么我们只需要使用一个四位的BCD码就足够了。
细心的朋友会发现当数字大于九时,一个四位的BCD码不能够表达十进制的两位数,因此当数字大于九时,我们需要用八位BCD码来表示。高位只需要逢九进一即可。
(三)BCD码如果进行加法运算?
⑻ 怎么求压缩BCD码
BCD码 就是把10进制数转成4位1节的2进制编码,每节表示1位。
方法:将10进制数的每一位转成相应的2进制即可。
例: 1357
-> 0001(1) 0011(3) 0101(5) 0111(7)
->0001001101010111
⑼ 压缩bcd码与非压缩bcd码的转化
压缩的BCD码和非压缩的,区别就在于,一个字节存储几位数。压缩的两位,非压缩的一位。
像你问题中的,0409h,压缩的应该是49h,,,而31h正好是十进制的49.。可能你碰到的问题没有阐述全吧。。。
能在详细的说一下么。
⑽ 什么是压缩BCD码和非压缩BCD码
压缩BCD码是用四位二进制数表示一位BCD码,用一个字节表示的两位BCD码,即一个字节存放两个十进制数位,想到压缩BCD码更节省存储空间。
非压缩BCD码:非压缩型BCD码一个字节可存放一个一位十进制数,其中高4位的内容不做规定(也有部分书籍要求为0,二者均可),低4位二进制表示该位十进制数。
非压缩BCD码在汇编中的调整指令为AAA(加法的ASCII码调整)、AAS(减法的ASCII码调整)、AAM(乘法的ASCII码调整)、AAD(除法的ASCII码调整)。
(10)压缩BCD码扩展阅读:
调试时使用的数据:
ORG 0000H
MOV 20H, #12H ;假设被加数NA是563412
MOV 21H, #34H
MOV 22H, #56H
MOV 30H, #77H ;假设加数NB是998877
MOV 31H, #88H
MOV 32H, #99H
LCALL ADD3B ;调用3字节加法子程序
SJMP $ ;相加结束,暂停,此时可以观察到和的数值:1562289