`

BCD码

    博客分类:
  • java
 
阅读更多
注意:是4位表示一个10进制数字,一个字节8位,这样是要把字节拆分的哦!

BCD码 编辑
BCD码(Binary-Coded Decimal‎)亦称二进码十进数或二-十进制代码。用4位二进制数来表示1位十进制数中的0~9这10个数码。是一种二进制的数字编码形式,用二进制编码的十进制代码。BCD码这种编码形式利用了四个位元来储存一个十进制的数码,使二进制和十进制之间的转换得以快捷的进行。这种编码技巧最常用于会计系统的设计里,因为会计制度经常需要对很长的数字串作准确的计算。相对于一般的浮点式记数法,采用BCD码,既可保存数值的精确度,又可免去使电脑作浮点运算时所耗费的时间。此外,对于其他需要高精确度的计算,BCD编码亦很常用。
由于十进制数共有0、1、2、……、9十个数码,因此,至少需要4位二进制码来表示1位十进制数。4位二进制码共有2^4=16种码组,在这16种代码中,可以任选10种来表示10个十进制数码,共有N=16!/[10!*(16-10)!]等于8008种方案。常用的BCD代码列于末。
中文名 二进码十进数 外文名 Binary-Coded Decimal‎ 简    称 BCD码 别    名 二-十进制代码
目录
1 分类
▪ 8421
▪ 5421和2421
▪ 余3 码
▪ Gray码
2 编码方式
3 特点
4 举例
分类编辑
BCD码可分为有权码和无权码两类:有权BCD码有8421码、2421码、5421码,其中8421码是最常用的;无权BCD码有余3码,余3循环码等。
8421
8421 BCD码是最基本和最常用的BCD码,它和四位自然二进制码相似,各位的权值为8、4、2、1,故称为有权BCD码。和四位自然二进制码不同的是,它只选用了四位二进制码中前10组代码,即用0000~1001分别代表它所对应的十进制数,余下的六组代码不用。
5421和2421
5421 BCD码和2421 BCD码为有权BCD码,它们从高位到低位的权值分别为5、4、2、1和2、4、2、1。这两种有权BCD码中,有的十进制数码存在两种加权方法,例如,5421 BCD码中的数码5,既可以用1000表示,也可以用0101表示;2421 BCD码中的数码6,既可以用1100表示, 也可以用0110表示。这说明5421 BCD码和2421 BCD码的编码方案都不是惟一的,表1-2只列出了一种编码方案。
上表中2421 BCD码的10个数码中,0和9、1和8、2和7、3和6、4和5的代码对应位恰好一个是0时,另一个就是1。就称0和9、1和8互为反码。
余3 码
余3码是8421 BCD码的每个码组加3(0011)形成的。常用于BCD码的运算电路中。
Gray码
Gray码也称循环码,其最基本的特性是任何相邻的两组代码中,仅有一位数码不同,因而又叫单位距离码。
Gray码的编码方案有多种,典型的Gray码如下表所示。从表中看出,这种代码除了具有单位距离码的特点外,还有一个特点就是具有反射特性,即按表中所示的对称轴为界,除最高位互补反射外,其余低位数沿对称轴镜像对称。利用这一反射特性可以方便地构成位数不同的Gray码。[1]
编码方式编辑
最常用的BCD编码,就是使用"0"至"9"这十个数值的二进码来表示。这种编码方式,在称之为“8421码”(日常所说的BCD码大都是指8421BCD码形式)。除此以外,对应不同需求,各人亦开发了不同的编码方法,以适应不同的需求。这些编码,大致可以分成有权码和无权码两种:
有权BCD码,如:8421(最常用)、2421、5421…
无权BCD码,如:余3码、格雷码…(注意:格雷码并不是BCD码)
以下为三种常见的BCD编码的比较。
十进数 8421-BCD码 余3-BCD码 2421-A码
(M10) DCBA C3C2C1C0 a3a2a1a0
0 - 0 0 0 0 / 0 0 1 1 / 0 0 0 0
1 - 0 0 0 1 / 0 1 0 0 / 0 0 0 1
2 - 0 0 1 0 / 0 1 0 1 / 0 0 1 0
3 - 0 0 1 1 / 0 1 1 0 / 0 0 1 1
4 - 0 1 0 0 / 0 1 1 1 / 0 1 0 0
5 - 0 1 0 1 / 1 0 0 0 / 1 0 1 1
6 - 0 1 1 0 / 1 0 0 1 / 0 1 1 0
7 - 0 1 1 1 / 1 0 1 0 / 0 1 1 1
8 - 1 0 0 0 / 1 0 1 1 / 1 1 1 0
9 - 1 0 0 1 / 1 1 0 0 / 1 1 1 1
常用BCD码
十进制数 8421码 5421码 2421码 余3码 余3循环码
0 0000 0000 0000 0011 0010
1 0001 0001 0001 0100 0110
2 0010 0010 0010 0101 0111
3 0011 0011 0011 0110 0101
4 0100 0100 0100 0111 0100
5 0101 1000 1011 1000 1100
6 0110 1001 1100 1001 1101
7 0111 1010 1101 1010 1111
8 1000 1011 1110 1011 1110
9 1001 1100 1111 1100 1010
-----------------------
特点编辑
8421编码直观,好理解。
5421码和2421码中大于5的数字都是高位为1,5以下的高位为0。
余3码是8421码加上3,有上溢出和下溢出的空间。
格雷码相邻2个数有三位相同,只有一位不同。
举例编辑
某二进制无符号数11101010,转换为三位非压缩BCD数,按百位、十位和个位的顺序表示,应为<U>__C</U>__。
A.00000001 / 00000011 / 00000111  B. 00000011 / 00000001 / 00000111
C.00000010 / 00000011 / 00000100  D. 00000011 / 00000001 / 00001001
解:(1)11101010转换为十进制:234
(2)按百位、十位和个位的顺序表示,应为<U>__C</U>__。
附注:压缩BCD码与非压缩BCD码的区别—— 压缩BCD码的每一位用4位二进制表示,一个字节表示两位十进制数。例如10010110B表示十进制数96D;非压缩BCD码用1个字节表示一位十进制数,高四位总是0000,低4位的0000~1001表示0~9.例如00001000B表示十进制数8.
BCD码的运算法则
BCD码的运算规则:BCD码是十进制数,而运算器对数据做加减运算时,都是按二进制运算规则进行处理的。这样,当将 BCD码传送给运算器进行运算时,其结果需要修正。修正的规则是:当两个BCD码相加,如果和等于或小于 1001(即十进制数9),不需要修正;如果相加之和在 1010 到1111(即十六进制数 0AH~0FH)之间,则需加 6 进行修正;如果相加时,本位产生了进位,也需加 6 进行修正。这样做的原因是,机器按二进制相加,所以 4 位二进制数相加时,是按“逢十六进一”的原则进行运算的,而实质上是 2 个十进制数相加,应该按“逢十进一”的原则相加,16 与10相差 6,所以当和超过 9或有进位时,都要加 6 进行修正。下面举例说明。
【例 1.3】 需要修正 BCD码运算值的举例。
(1) 计算 5+8;(2) 计算 8+8
解:(1) 将 5 和 8 以 8421 BCD输入机器,则运算如下:
0 1 0 1
+) 1 0 0 0
1 1 0 1 结果大于 9
+) 0 1 1 0 加 6 修正
1 0 0 1 1 即13 的 BCD码
结果是 0011,即十进制数3,还产生了进位。5+8=13,结论正确。
(2)将8以8421 BCD输入机器,则运算如下:
1 0 0 0
+)1 0 0 0
1 0 0 0 0 结果大于9
+)0 1 1 0 加6修正
1 0 1 1 0 16的BCD码
结果是0110,即十进制的6,而且产生进位。8+8=16,结论正确。
微机原理代码: (AL=BCD 5,BL=BCD 8) 设AH=0,则
ADD AL,BL
AAA
结果为 AX=0103H,表示非压缩十进制数,CF=1,AF=1,AH=1,AL=3
使用AAA指令,可以不用屏蔽高半字节,只要在相加后立即执行AAA指令,便能在AX中得到一个正确的非压缩十进制数


public static String toBCDString(byte bcd) {
        StringBuffer sb = new StringBuffer();

        byte high = (byte) (bcd & 0xf0);
        high >>>= (byte) 4;
        high = (byte) (high & 0x0f);
        byte low = (byte) (bcd & 0x0f);

        sb.append(high);
        sb.append(low);

        return sb.toString();
    }
分享到:
评论

相关推荐

    双字节BCD码加法实验报告

    双字节BCD码加法实验是对嵌入式系统基础知识的一种实践操作,主要涉及汇编语言编程和BCD码的运算。在这个实验中,学生使用了wave6000软件来实现双字节BCD码的加法运算,旨在熟悉wave6000的使用以及掌握循环程序的...

    数字电子技术课程设计--将8421BCD码转换成5421BCD码的电路设计.docx

    《数字电子技术课程设计——8421BCD码到5421BCD码转换电路》 在数字电子技术领域,数据编码是至关重要的环节。8421BCD码(Binary-Coded Decimal,二进制编码的十进制数)是一种广泛使用的十进制数的二进制表示方式...

    八位二进制转bcd码

    **八位二进制转BCD码** 在数字电子技术中,二进制编码十进制(Binary-Coded Decimal,简称BCD码)是一种将十进制数字转换为二进制表示的方法,常用于计算机系统中处理数值数据,特别是在显示和打印数字时。BCD码的...

    数字电子技术课程设计--将8421BCD码转换成5421BCD码的电路设计.pdf

    本课程设计的主题是将8421BCD码转换成5421BCD码的电路设计,这一任务对于理解和掌握数字逻辑电路及其应用至关重要。8421BCD码和5421BCD码都是二进制编码的十进制数表示方式,它们之间的转换是数字电路设计中的常见...

    BCD码 基础知识

    BCD 码基础知识 BCD 码(Binary Coded Decimal)是一种用二进制编码表示的十进制数,是人们最常用的。它可以用两种格式来表示:压缩的 BCD 码和非压缩的 BCD 码。 压缩的 BCD 码用 4 位二进制数表示一个十进制数位...

    十进制数转换成BCD码(源码)

    在计算机科学和自动化控制领域,BCD码(Binary-Coded Decimal,二进制编码的十进制数)是一种用于表示十进制数的二进制编码方式。它将每个十进制位用四位二进制数来表示,使得数字处理更加直观且适合硬件实现。在...

    汇编语言BCD码加法

    在深入探讨汇编语言中的BCD码加法之前,我们首先需要理解BCD(Binary-Coded Decimal)码的基本概念。BCD码是一种将十进制数转换为二进制形式的编码方式,它将每个十进制数字用四位二进制数表示。这种编码方式在处理...

    二进制转换成BCD码

    二进制转换成BCD码 本资源是一个将二进制数转换成BCD码的VHDL代码,提供32位转换,可以自行扩展。下面是对该代码的详细解释和知识点总结: 二进制和BCD码 在计算机科学中,二进制是最基本的数制,使用0和1两个...

    BCD关于BCD码在PLC数据转换

    **BCD码在PLC数据转换中的应用** BCD(Binary Coded Decimal,二进制编码的十进制)码是一种特殊的数据表示方式,主要用于在计算机系统中存储和处理十进制数字。在PLC(Programmable Logic Controller,可编程逻辑...

    BCD码加法程序

    本项目中的"BCD码加法程序"是一个自编的用于演示和学习BCD码加法运算的程序,具有开源性质,鼓励大家互相交流和学习。 BCD码通常有两种主要类型:直接编码和位组编码。直接编码将每一位十进制数字直接转换为4位二...

    日期时间转换成ASC码或者BCD码

    ASC码(ASCII码)和BCD码(二进制编码的十进制数)是两种常见的编码方式,用于将日期和时间转换为数字格式,便于计算机处理。下面将详细介绍这两种编码方式以及它们在日期时间转换中的应用。 首先,ASCII码...

    压缩式BCD码分解成为单字节BCD码

    ### 压缩式BCD码分解成为单字节BCD码 #### 概述 在数字电子系统中,BCD(Binary-Coded Decimal,二进制编码十进制)是一种非常重要的编码方式,广泛应用于计算器、时钟以及其他需要处理十进制数值的设备或系统中。...

    verilog 16进制转10进制bcd码

    ### Verilog 16进制转10进制BCD码转换器详解 #### 核心概念解析 本文档详细解析了一个Verilog程序,该程序实现了16进制数到二进制编码十进制(Binary Coded Decimal, BCD)格式的转换,并最终用于驱动数码管显示。...

    工程说明_verilog十进制转BCD码_

    在这个工程中,我们将讨论如何使用`Verilog`实现一个将32位十进制数据转换为BCD码的模块。 BCD码是一种特殊形式的二进制编码,用于表示十进制数。每四位二进制代表一个十进制数位,例如0000到1001分别代表0到9。...

    16位二进制转化为BCD码.zip_16bit bcd_16位bcd码_16位bcd码范围_verilog_二进制 BCD

    在计算机科学和数字电路设计中,二进制编码十进制(Binary-Coded Decimal,简称BCD码)是一种特殊的数据编码方式,它将每一位十进制数用四位二进制数来表示。BCD码的主要目的是为了在处理十进制数值时能够更直观和...

    二进制换BCD码(内含完整C语言的代码)

    二进制转换为BCD码(Binary-Coded Decimal,简称BCD码)是计算机处理数字的一种方式,尤其在处理与人类可读的十进制数交互时非常有用。BCD码将每一位十进制数映射到4位二进制上,每四位二进制代表一位十进制数。例如...

    微机原理与接口技术/汇编实验 两个压缩的BCD码相减并调整结果为压缩的BCD码实验报告

    实验3-3主要探讨了如何在微机系统中使用汇编语言处理压缩的BCD码(Binary Coded Decimal)的减法操作,并将其结果显示在屏幕上。BCD码是一种用于表示十进制数字的二进制编码方式,压缩的BCD码则用四位二进制来表示一...

    4位BCD码加法器的设计

    在本项目中,我们探讨的是如何设计一个4位BCD码加法器,这是ALU功能的一个具体应用。BCD码(Binary-Coded Decimal,二进制编码的十进制数)是一种将十进制数字转换为二进制表示的方法,它在处理十进制数据时非常有用...

    两个BCD码的加法运算电路

    BCD码,全称为二进制编码的十进制数(Binary-Coded Decimal),是一种将十进制数用二进制表示的方法。在数字电子电路中,BCD码的使用非常广泛,特别是在需要精确处理十进制数据的场合,如计算器、数字显示设备等。本...

Global site tag (gtag.js) - Google Analytics