0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

CRC为什么是数据通信领域中最常用的一种查错校验码?

GReq_mcu168 来源:玩转单片机 作者:玩转单片机 2020-07-01 17:10 次阅读

UART有一个奇偶校验,CAN通信有CRC校验。Modbus、MAVlink、USB等通信协议也有校验信息

在自定义数据存储时,有经验的工程师都会添加一定校验信息。

你平时通信,或者数据存储时,你有用到校验信息吗?下面就介绍几种常见的校验算法

一、校验和

校验和是最基本,也是嵌入式工程师最常用的一种校验算法,其实现方法很简单,简单到只有几行代码。

实现的方式方法很多,不同的编程语言,不同的应用有所不同,下面以C语言8位校验和为例:

uint8_t CheckSum(uint8_t *Buf, uint8_t Len){uint8_t i = 0;uint8_t sum = 0;uint8_t checksum = 0;

for(i=0; i《Len; i++) { sum += *Buf++; }

checksum = sum & 0xff;

return checksum;}

二、异或校验

【异或校验】与【校验和】类似,对数据进行“异或”,最终得到一个“异或值”。

uint8_t CheckXOR(uint8_t *Buf, uint8_t Len){uint8_t i = 0;uint8_t x = 0;

for(i=0; i《Len; i++) { x = x^(*(Buf+i)); }

return x;}

校验和、异或校验的方式有很多种,比如有的还会传入一个参数作为异或校验的值。

当然,以上代码仅供学习参考,实际应用需结合项目情况修改代码。

三、CRC校验

CRC:Cyclic Redundancy Check,即循环冗余校验。

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

CRC校验属于冗余校验中的一种,大学学计算机相关专业的同学都应该学过CRC校验(学习时可能没几个同学搞明白了)

CRC有多种变体,比如:CRC-1、 CRC-5-USB、 CRC-8、 CRC-16、 CRC-32、 CRC-64等。其中,在嵌入式领域,CRC-16用的比较多。

常见CRC参数模型:

CRC为什么是数据通信领域中最常用的一种查错校验码?

比如一种在单片机上实现CRC16的源码:

uint8_t CRCTAB_H[256] = {/*表省略*/};uint8_t CRCTAB_L[256] = {/*表省略*/};void CRC16(uint8_t *pData, uint8_t Len, uint8_t *CRC_H, uint8_t *CRC_L){uint8_t i;uint8_t index;uint8_t crc_h = 0xFF;uint8_t crc_l = 0xFF;

for(i=0; i《Len; i++) { index = crc_h^*(pData + i); crc_h = crc_l^CRCTAB_H[index]; crc_l = CRCTAB_L[index]; }

*CRC_H = crc_h; *CRC_L = crc_l;}

CRC校验不同场景实现方式不同,网上也有很多公开的库和源码,比如:

LibCRC – C语言中的开源CRC库:

网上还有在线计算CRC校验值以及代码生成工具,感兴趣的读者可以自行了解。

四、MD5算法

MD5:Message-Digest Algorithm 5,即“信息-摘要算法。

从名字来看就知道它是从MD3、MD4发展而来的一种加密算法,其主要通过采集文件的信息摘要,以此进行计算并加密。

通过MD5算法进行加密,文件就可以获得一个唯一的MD5值,这个值是独一无二的,就像我们的指纹一样,因此我们就可以通过文件的MD5值来确定文件是否正确,密码进行加密后也会生成MD5值,论坛就是通过MD5值来验证用户的密码是否正确的。

CRC为什么是数据通信领域中最常用的一种查错校验码?

MD5是输入不定长度信息,输出固定长度128-bits的算法。经过程序流程,生成四个32位数据,最后联合起来成为一个128-bits散列。基本方式为,求余、取余、调整长度、与链接变量进行循环运算。得出结果。

MD5的源码在网上都能找到现成的,而且有不同编程语言(C、 C++JAVA)版本。

五、其他算法

随着变成技术越来越发达,校验算法也越来越多,有通用的算法,也有特殊领域特定的算法。

比如我之前做过密码相关的开发,使用了由密码管理局发布的SM3密码杂凑算法。

还有从MD4算法改进而来的SHA-1算法(Secure Hash Algorithm 1即安全散列算法1)。
责任编辑:pj

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据传输
    +关注

    关注

    9

    文章

    1526

    浏览量

    63562
  • crc
    crc
    +关注

    关注

    0

    文章

    191

    浏览量

    29195
  • 数据通信
    +关注

    关注

    2

    文章

    395

    浏览量

    33521
收藏 人收藏

    评论

    相关推荐

    数据通信系统的组成 数据通信系统的主要技术指标

    数据通信系统是由多个组件组成的,主要包括发送端、接收端、传输介质和通信协议。数据通信系统的主要技术指标包括传输速率、端到端延迟、误码率、带宽、可靠性等方面。 首先,发送端是数据通信系统
    的头像 发表于 01-24 17:06 827次阅读

    虹科技术 | 保障数据传输稳定性:BabyLIN产品的CRC算法实现

    CRC校验(循环冗余校验)是数据通中最常采用的校验方式。CAN协议中,总线
    的头像 发表于 01-02 17:23 237次阅读
    虹科技术 | 保障<b class='flag-5'>数据</b>传输稳定性:BabyLIN产品的<b class='flag-5'>CRC</b>算法实现

    虹科技术|保障数据传输稳定性:BabyLIN产品的CRC算法实现

    导读: CRC校验(循环冗余校验)是数据通中最常采用的校验方式。CAN协议中,总线
    的头像 发表于 01-02 10:45 198次阅读
    虹科技术|保障<b class='flag-5'>数据</b>传输稳定性:BabyLIN产品的<b class='flag-5'>CRC</b>算法实现

    瑞萨RA MCU中CRC模块的使用方法

    CRC(Cyclic Redundancy Check),即循环冗余校验码CRC数据通信领域中最常用
    的头像 发表于 12-07 10:23 1254次阅读
    瑞萨RA MCU中<b class='flag-5'>CRC</b>模块的使用方法

    如何在IAR Embedded Workbench中配置生成对应代码区域的CRC校验码

    在“使用IAR Embedded Workbench和MCU的CRC模块来检查代码的完整性”一文中,介绍了如何在IAR Embedded Workbench中配置生成对应代码区域的CRC校验码,然后
    的头像 发表于 10-27 11:49 863次阅读
    如何在IAR Embedded Workbench中配置生成对应代码区域的<b class='flag-5'>CRC</b><b class='flag-5'>校验码</b>

    基于CDMA的车载终端数据通信设计

    电子发烧友网站提供《基于CDMA的车载终端数据通信设计.pdf》资料免费下载
    发表于 10-20 11:01 0次下载
    基于CDMA的车载终端<b class='flag-5'>数据通信</b>设计

    奇偶校验crc校验的区别 CRC校验和奇偶校验之间有什么关系?

    奇偶校验crc校验的区别 CRC校验和奇偶校验之间有什么关系? 奇偶
    的头像 发表于 10-17 16:28 2456次阅读

    MWCSH 2023 | 华为数据通信亮点抢先看!

    点击“阅读原文”,了解更多大会信息! 原文标题:MWCSH 2023 | 华为数据通信亮点抢先看! 文章出处:【微信公众号:华为数据通信】欢迎添加关注!文章转载请注明出处。
    的头像 发表于 06-21 18:15 390次阅读
    MWCSH 2023 | 华为<b class='flag-5'>数据通信</b>亮点抢先看!

    CRC校验码的多种Verilog实现方式

    CRC循环冗余校验码(Cyclic Redundancy Check),检错码。
    的头像 发表于 06-21 15:03 2995次阅读
    <b class='flag-5'>CRC</b><b class='flag-5'>校验码</b>的多种Verilog实现方式

    SILERGY矽力杰数据通信的“指挥官”!

    SILERGY矽力杰数据通信的“指挥官”!
    的头像 发表于 06-07 15:19 775次阅读
    SILERGY矽力杰<b class='flag-5'>数据通信</b>的“指挥官”!

    单片机中几种常见的校验算法介绍

    CRC数据通信领域中最常用一种查错校验码,其特征是信息字段和
    发表于 06-05 14:25 986次阅读
    单片机中几种常见的<b class='flag-5'>校验</b>算法介绍

    数据通信之无线通信介绍

    利用无线电波的这种特性来进行数据通信。   图1 无线电波传播示意   1、电磁波谱   1862年,英国物理学家麦克斯韦通过大量的实验证明了电磁波的存在,并断言电磁波的传播速度等于光速,光波就是一种电磁波
    发表于 05-17 15:08

    在modbusRTU程序中,发送数据是的CRC和接收数据CRC校验之间有什么关系吗?

    在modbusRTU程序中,发送数据是的CRC和接收数据CRC校验之间有什么关系吗?他们是一
    发表于 05-05 16:06

    数据通信的特点

    数据通信容量大:数字化信息传输能够承载大量的信息,不受受限于传输媒介的物理容量,舒适服务大范围用户以及复杂的业务场景。
    发表于 05-05 14:47 1591次阅读

    数据通信的基本概念

    数据通信通信技术和计算机技术相结合而产生的一种新的通信方式。要在两地间传输信息必须有传输信道,根据传输媒体的不同,有有线数据通信与无线
    发表于 05-05 14:44 2529次阅读