`
gelongmei
  • 浏览: 211703 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

几种常用的数据校验方式

阅读更多
我们知道数据在传输过程中,可能会存在数据出错的情况。为了保证数据传输的正确性,因此会采取一些方法来判断数据是否正确,或者在数据出错的时候及时发现进行改正。常用的几种数据校验方式有奇偶校验、CRC校验、LRC校验、格雷码校验、和校验、异或校验等。

一、奇偶校验

1. 定义

根据被传输的一组二进制代码中“1”的个数是奇数或偶数来进行校验。

使用:通常专门设置一个奇偶校验位,存放代码中“1”的个数为奇数还是偶数。若用奇校验,则奇偶校验位为奇数,表示数据正确。若用偶校验,则奇偶校验位为偶数,表示数据正确。

2. 应用

eg.  数据位为 10001100 (1)  -> 最后一位为校验位

此时若约定好为奇校验,那么数据表示为正确的,若为偶校验,那么数据传输出错了。

二、CRC校验(循环冗余校验码)

1. 定义

CRC校验是数据通信领域中最常用的一种查错校验码,其特征是信息字段和校验字段的长度可以任意选定。循环冗余检查(CRC)是一种数据传输检错功能,对数据进行多项式计算,并将得到的结果附在帧的后面,接收设备也执行类似的算法,以保证数据传输的正确性和完整性。

2. 计算过程:
a> 设置CRC寄存器,并给其赋值FFFF(hex)。
b> 将数据的第一个8-bit字符与16位CRC寄存器的低8位进行异或,并把结果存入CRC寄存器。
c> CRC寄存器向右移一位,MSB补零,移出并检查LSB。
d> 如果LSB为0,重复第三步;若LSB为1,CRC寄存器与多项式码相异或。

e> 重复第3与第4步直到8次移位全部完成。此时一个8-bit数据处理完毕。

f> 重复第2至第5步直到所有数据全部处理完成。

g> 最终CRC寄存器的内容即为CRC值。

常用的CRC循环冗余校验标准多项式如下:   CRC(16位) = X16+X15+X2+1   CRC(CCITT) = X16+X12 +X5+1
CRC(32位) = X32+X26+X23+X16+X12+X11+X10+X8+X7+X5+X4+X2+X+1
以CRC(16位)多项式为例,其对应校验二进制位列为1 1000 0000 0000 0101。

3. 应用:在发送端根据要传送的k位二进制码序列,以一定的规则产生一个校验用的r位监督码(CRC码),附在原始信息后边,构成一个新的二进制码序列数共k+r位,然后发送出去。在接收端,根据信息码和CRC码之间所遵循的规则进行检验,以确定传送中是否出错。

三、LRC校验

1. 定义:LRC校验用于ModBus协定的ASCII模式,这各校验比较简单,通讯速率较慢,它在ASCII协议中使用,检测了消息域中除开始的冒号及结束的回车换行号外的内容。它仅仅是把每一个需要传输的数据字节迭加后取反加1即可。

2. 应用

eg. 5个字节:01H+03H+21H+02H+00H+02H = 29H,然后取2的补码=D7H。

四、格雷码校验

1. 定义

格雷码是一种无权码,也是一种循环码。是指任意两组相邻的代码之间只有一位不同,其余为都相同。

如:5的二进制为0101    6的二进制为0110

        5的格雷码为0111    6的二进制为0101

五、校验和

1. 定义

校验一组数据项的和是否正确。通常是以十六进制为数制表示的形式。如果校验和的数值超过十六进制的FF,也就是255。

2. 应用

eg. 数据01020304的校验和为a。

六、异或校验

1. 定义

BCC校验其实是奇偶校验的一种,但也是经常使用并且效率较高的一种。所谓BCC校验法,就是在发送前和发送后分别把BCC以前包括ETX字符的所有字符按位异或后,按要求变换(增加或去除一个固定的值)后所得到的字符进行比较。相等即认为通信无错误,不相等则认为通信出错。

七、MD5校验

1. 定义

MD5的实际应用是对一段Message(字节串)产生fingerprint(指纹),可以防止被篡改。





版权声明:本文为博主原创文章,未经博主允许不得转载。 http://blog.csdn.net/zhengqijun_/article/details/53150749
分享到:
评论

相关推荐

    常用数据校验源代码(CRC8 CRC16 和校验 异或校验)

    本文介绍了几种常用的数据校验方法及其C++实现。通过这些方法,可以在一定程度上提高数据传输的准确性和可靠性。需要注意的是,在实际应用中还需要考虑具体的场景和需求选择最适合的校验方式。 通过本篇介绍,希望...

    串口MSComm控件五种不同校验方式

    串行通信是一种数据传输方式,其中数据是以序列形式逐位传输的。在计算机硬件中,RS232、RS485、RS422是最常见的串行通信接口标准,用于设备间的短距离数据交换。 #### 二、MSComm控件与校验方式 MSComm控件是...

    单片机常用校验方法

    常见的校验方法有奇偶校验、CRC、MD5、BCC 等十几种。 一、奇偶校验 奇偶校验是一种简单的错误检测方法,每个字节(8 位)之外增加一位作为错误检测位。在某字节中存储数据之后,在其 8 个位上存储的数据是固定的...

    文件校验数据必备

    首先,我们需要了解几种常见的校验算法,例如MD5(Message-Digest Algorithm 5)、SHA-1(Secure Hash Algorithm 1)和SHA-256等。这些算法将文件内容转化为固定长度的唯一数字串,即校验码。如果文件内容不变,校验...

    数据发送与接收校验(校验和)_数据校验之校验和_

    数据校验之校验和的重要性在于,它可以提高数据通信的可靠性,防止错误的数据被接收和处理。例如,在网络传输中,TCP 协议就使用了校验和来确保数据段的完整性;在硬盘存储中,文件系统如 FAT 或 NTFS 也会利用校验...

    基于LabVIEW的串口通信数据校验和的实现方法

    为了确保数据传输的准确性,避免通信差错,本文重点介绍了几种常用的检错方法,包括异或和(XOR Sum)、校验和(Checksum)、循环冗余校验(Cyclic Redundancy Check, CRC)。其中,校验和方法因其简单实用而在一般...

    数据校验码(奇偶校验码 海明校验码 循环冗余校验码)

    在选择校验策略时,需要根据应用的具体需求,比如错误容忍度、资源消耗和性能要求等因素,来决定使用哪一种数据校验码技术。随着技术的进步和应用需求的多样化,数据校验码也在不断演进,为我们的数字世界提供更加...

    javascript 常用校验代码

    在JavaScript中,数据校验主要针对以下几个方面: 1. **用户输入校验**:这通常涉及到表单数据,如电子邮件地址、手机号码、密码强度等。例如,可以使用正则表达式来验证电子邮件地址的格式是否正确,或者检查密码...

    计算机组成原理:2.3.34 数据信息的校验.ppt

    数据校验通过添加额外的校验位来检测潜在的错误。本节主要介绍了三种常见的校验方法:奇偶校验、海明校验以及CRC循环冗余校验。 1. 奇偶校验: 奇偶校验是最简单的错误检测方法,分为奇校验和偶校验。在奇校验中,...

    计算机组成原理中的三种校验方式.ppt

    计算机组成原理中的三种校验方式是计算机系统中的一种重要机制,用于检测和纠正数据传输过程中的错误。本文将详细介绍计算机组成原理中的三种校验方式,即冗余校验、奇偶校验和海明码校验方法。 一、冗余校验方法 ...

    Struts2数据校验

    接下来,我们将深入探讨Struts2的几种数据校验方式: 1. **注解式校验**:在Action类的字段上直接使用Java Bean Validation提供的注解,如`@NotBlank`、`@Min`、`@Max`等。这种方式简单直观,适用于快速开发。例如...

    数据BCC校验码计算工具

    BCC校验码是一种常用的错误检测机制,尤其在通信和数据存储领域中广泛使用,以确保数据在传输或存储过程中的完整性。 BCC,全称为Block Check Character,也被称为块校验字符,其基本原理是通过计算数据块中所有...

    CalcCRC 数据校验工具

    其中,CRC(Cyclic Redundancy Check,循环冗余校验)是一种广泛应用的数据校验方法。本文将详细介绍名为"CalcCRC"的数据校验工具,它可以帮助我们快速计算并验证CRC校验码,以保证数据的完整性。 CRC校验是一种...

    行业分类-物理装置-一种数据校验的方法、装置、介质和电子设备.zip

    标题中的“行业分类-物理装置-一种数据校验的方法、装置、介质和电子设备”表明了这个主题聚焦在信息技术领域,特别是与数据处理、物理装置和电子设备相关的数据校验技术。这种技术对于确保数据的准确性和系统的可靠...

    CRC校验码生成与数据校验源码程序 (包括CRC-4,5,6,7,8,16,32)

    CRC(Cyclic Redundancy Check,循环冗余校验)是一种广泛用于数据传输和存储中的错误检测方法。它通过在数据后面附加一个校验码来确保数据的完整性。本资源包含CRC-4、5、6、7、8、16、32的非查表法实现,这是一种...

    常用Struts校验器

    本文将详细介绍Struts中的几种常用校验器及其配置方法。 #### 1. Regex校验器 Regex校验器用于对输入进行正则表达式匹配。例如,在文件中出现的`<field-validator type="regex">`元素就是用来实现正则校验的。 ``...

    CRC简单的几个校验方式

    CRC(Cyclic Redundancy Check,循环冗余校验)是一种广泛用于数据传输和存储中的错误检测方法。它通过在数据后面附加一个校验码来确保数据的完整性,如果数据在传输过程中发生改变,接收方进行CRC校验时将无法得到...

    CRC8数据校验VB6.0编写

    在VB6.0(Visual Basic 6.0)环境中,我们可以编写程序来实现CRC8的数据校验功能,以确保数据的完整性和准确性。 CRC校验的基本原理是基于多项式除法,它通过将数据看作是二进制多项式的系数,并与一个预定义的生成...

    C# 异或校验含源码

    了解这些概念和实现方式对于理解和处理涉及数据校验的项目至关重要,特别是在GPS通信、网络传输或者任何需要确保数据完整性的场景下。源码分析和实践可以帮助开发者深入理解这些机制,提高代码质量,并能应用于其他...

    右键属性文件校验插件可同时生成十几种校验码(MD5 CRC32 SHA1)

    CRC32(Cyclic Redundancy Check 32)是另一种常见的校验方法,主要用于检测数据传输过程中的错误。它通过一个特定的算法生成一个32位的校验码,如果数据在传输过程中有误,CRC32值通常会发生变化。虽然CRC32不如MD5...

Global site tag (gtag.js) - Google Analytics