什么是CRC? CRC检测又有什么意思?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了什么是CRC? CRC检测又有什么意思?相关的知识,希望对你有一定的参考价值。

谢谢各位大侠,告知小弟CRC是什么?

CRC可以说是一种非常优秀的检测手段~

在数据存储和数据通讯领域,为了保证数据的正确,就不得不采用检错的手段。在诸多检错手段中,CRC是最著名的一种。CRC的全称是循环冗余校验,其特点是:检错能力极强,开销小,易于用编码器及检测电路实现。从其检错能力来看,它所不能发现的错误的几率仅为0.0047%以下。从性能上和开销上考虑,均远远优于奇偶校验及算术和校验等方式。因而,在数据存储和数据通讯领域,CRC无处不在:著名的通讯协议X.25的FCS(帧检错序列)采用的是CRC-CCITT,ARJ、LHA等压缩工具软件采用的是CRC32,磁盘驱动器的读写采用了CRC16,通用的图像存储格式GIF、TIFF等也都用CRC作为检错手段。
CRC的本质是模-2除法的余数,采用的除数不同,CRC的类型也就不一样。通常,CRC的除数用生成多项式来表示。最常用的CRC码的生成多项式如表1所示。
@@10A08800.GIF;表1.最常用的CRC码及生成多项式@@
由于CRC在通讯和数据处理软件中经常采用,笔者在实际工作中对其算法进行了研究和比较,总结并编写了一个具有最高效率的CRC通用程序库。该程序采用查表法计算CRC,在速度上优于一般的直接模仿硬件的算法,可以应用于通讯和数据压缩程序。
通常的CRC算法在计算一个数据段的CRC值时,其CRC值是由求解每个数值的CRC值的和对CRC寄存器的值反复更新而得到的。这样,求解CRC的速度较慢。通过对CRC算法的研究,我们发现:一个8位数据加到16位累加器中去,只有累加器的高8位或低8位与数据相作用,其结果仅有256种可能的组合值。因而,我们可以用查表法来代替反复的运算,这也同样适用于CRC32的计算。本文所提供的程序库中,函数crchware是一般的16位CRC的算法;mk-crctbl用以在内存中建立一个CRC数值表;crcupdate用以查表并更新CRC累加器的值;crcrevhware和crcrevupdate是反序算法的两个函数;BuildCRCTable、CalculateBlockCRC32和UpdateCharac
terCRC32用于CRC32的计算。
/* CRC.C——CRC程序库 */
#define CRCCCITT 0x1021
#define CCITT-REV 0x8408
#define CRC16 0x8005
#define CRC16-REV 0xA001
#define CRC32-POLYNOMIAL 0xEDB88320L
/* 以上为CRC除数的定义 */
#define NIL 0
#define crcupdate(d,a,t)*(a)=(*(a)<<8)^(t)[(*(a)>>8)^(d)];
#define crcupdate16(d,a,t)*(a)=(*(a)>>8^(t)[(*(a)^(d))&0x00ff])
/* 以上两个宏可以代替函数crcupdate和crcrevupdate */
#include<stdio.h>
#include<stdlib.h>
#include<alloc.h>
/* 函数crchware是传统的CRC算法,其返回值即CRC值 */
unsigned short crchware(data,genpoly,accum)
unsigned short data;/* 输入的数据 */
unsigned short genpoly;/* CRC除数 */
unsigned short accum;/* CRC累加器值 */

static int i;
data<<=8;
for(i=8;i>0;i--)

if((data^accum)&0x8000)
accum=(accum<<1)^genpoly;
else
accum<<=1;
data<<=1;

return (accum);

/* 函数mk-crctbl利用函数crchware建立内存中的CRC数值表 */
unsigned short *mk-crctbl(poly,crcfn);
unsigned short poly;/* CRC除数--CRC生成多项式 */R>unsigned short (*crcfn)();/* 指向CRC函数(例如crchware)的指针 */

/* unsigned short */malloc(); */
unsigned short *crctp;
int i;
if((crctp=(unsigned short*)malloc(256*sizeof(unsigned)))==0)
return 0;
for(i=0;i<256;i++)
crctp[i]=(*crcfn)(i,poly,0);
return crctp;

/* 函数mk-crctbl的使用范例 */
if((crctblp=mk-crctbl(CRCCCITT,crchware))==NIL)

puts(insuff memory for CRC lookup table.\n);
return 1; */
/* 函数crcupdate用以用查表法计算CRC值并更新CRC累加器值 */
void crcupdate(data,accum,crctab)
unsigned short data;/* 输入的数据 */
unsigned short *accum;/* 指向CRC累加器的指针 */
unsigned short *crctab;/* 指向内存中CRC表的指针 */

static short comb-val;
comb-val=(*accum>>8)^data;
*accum=(*accum<<8)^crctab[comb-val];

/* 函数crcrevhware是传统的CRC算法的反序算法,其返回值即CRC值 */
unsigned short crcrevhware(data,genpoly,accum)
unsigned short data;
unsigned short genpoly;
unsigned short accum;

static int i;
data<<=1;
for(i=8;i>0;i--)

data>>=1;
if((data^accum)&0x0001)
accum=(accum>>1)^genpoly;
else
accum>>=1;

return accum;

/* 函数crcrevupdate用以用反序查表法计算CRC值并更新CRC累加器值 */
void crcrevupdate(data,accum,crcrevtab)
unsigned short data;
unsigned short *accum;
参考技术A CRC:循环冗余码校验cyclical (cyclic) redundancy check 的缩写.
CRC检测:CRC错误检测法根据所传数据在传送前的纠错.(来自<微软英汉双解
计算机百科辞典.)
以上两条所答非所问,报歉.
参考技术B CRC:循环冗余码校验cyclical
(cyclic)
redundancy
check
的缩写.
CRC检测:CRC错误检测法根据所传数据在传送前的纠错.(来自<微软英汉双解
计算机百科辞典.)
以上两条所答非所问,报歉.
参考技术C CRC检测
使用RTU模式,消息包括了一基于CRC方法的错误检测域。CRC域检测了整个消息的内容。
CRC域是两个字节,包含一16位的二进制值。它由传输设备计算后加入到消息中。接收设备重新计算收到
消息的CRC,并与接收到的CRC域中的值比较,如果两值不同,则有误。
CRC是先调入一值是全“1”的16位寄存器,然后调用一过程将消息中连续的8位字节各当前寄存器中的值
进行处理。仅每个字符中的8Bit数据对CRC有效,起始位和停止位以及奇偶校验位均无效。
CRC产生过程中,每个8位字符都单独和寄存器内容相或(OR),结果向最低有效位方向移动,最高有效位
以0填充。LSB被提取出来检测,如果LSB为1,寄存器单独和预置的值或一下,如果LSB为0,则不进行。整个
过程要重复8次。在最后一位(第8位)完成后,下一个8位字节又单独和寄存器的当前值相或。最终寄存器中
的值,是消息中所有的字节都执行之后的CRC值。
CRC添加到消息中时,低字节先加入,然后高字节。CRC简单函数如下:

unsigned short CRC16(puchMsg, usDataLen)

unsigned char *puchMsg ; /* 要进行CRC校验的消息 */

unsigned short usDataLen ; /* 消息中字节数 */



unsigned char uchCRCHi = 0xFF ; /* 高CRC字节初始化 */

unsigned char uchCRCLo = 0xFF ; /* 低CRC 字节初始化 */

unsigned uIndex ; /* CRC循环中的索引 */

while (usDataLen--) /* 传输消息缓冲区 */



uIndex = uchCRCHi ^ *puchMsgg++ ; /* 计算CRC */

uchCRCHi = uchCRCLo ^ auchCRCHi[uIndex ;

uchCRCLo = auchCRCLo[uIndex] ;



return (uchCRCHi << 8 | uchCRCLo) ;

参考资料:http://www.jcsepi.com/modbus/about_modbus2.htm

本回答被提问者采纳

CRC校验失败怎么办?

CRC即循环冗余校验码,CRC校验失败可能原因和解决方法如下:

1、可能是安装包有问题 从新下载个安装包就好了。

2、有错误文件。解决方法:试着在解压时勾选保留错误文件,如果不行的话看看杀毒软件里是不是把这个文件隔离了。

3、可能是硬件原因,比如内存不够。只能换硬件了

校验原理

系统内部预先设置根据校验方法所导出的校验公式编制成的校验程序,当带有校验码的代码输入系统时,系统利用校验程序对输入的本体码进行运算得出校验结果之后,再将校验结果与输入代码的校验码进行对比来检测输入的正确与否。

如果两者一致,则表明代码输入正确,系统允许进入,如果不一致,则表明代码输入有误,系统拒绝进入,并要求代码重新输入。

参考技术A crc校验失败,在保证算法没错的情况下,只说明一件事情,就是数据不对
由于crc只是校验,无法纠错,所以对于校验出错的数据只能抛弃
至于后续,如果是存储数据,那么需要做恢复初始化操作
如果是数据传输,那么根据数据重要性确定是不是要重传
参考技术B 回答

你好可能由于您长时间停留在该页没有刷新,或因输入不正确的验证码所导致。先“刷新”,然后及时输入验证码等信息,以便正常使用网上银行。若反复出现超时提示,请您尝试以下操作:(1)打开IE浏览器,选择“工具”菜单-->“Internet选项” 【高级】标签-->点击“还原默认设置”后确定退出。【常规】标签-->点击“Internet临时文件”中的“设置”-->“检查所存网页的较新版本”中选择“每次访问此页时检查”,点击 “删除文件”,在“删除所有脱机内容”前打勾后点击确定。(2)如果安装了3721上网助手,建议您将其完全卸载。

参考技术C CRC校验失败的可能原因和解决方法如下:

1.可能是安装包有问题。

解决方法:只需下载一个新的安装包。

2.有错误的文件。

解决方法:解压时尽量检查并保留错误的文件。

如果没有,请查看该文件是否在防病毒软件中被隔离。

3.可能是硬件原因,比如内存不足。

解决方法:只有硬件可以更改。解决内存问题。
参考技术D

如果有多个压缩包一起解压的那种,建议查看是否把全部压缩包都下载了,看看有没有全部选中一起解压

以上是关于什么是CRC? CRC检测又有什么意思?的主要内容,如果未能解决你的问题,请参考以下文章

什么是CRC校验码?

在这篇 Kmett CRC 文章中,为啥 ab = a0^n + 0^m b?这个符号是啥意思?

计算机网络CRC检验中为啥选择16或32位效验码,效率最高?

是否可以使用 CRC 进行基本的纠错?

CRC32 碰撞

*.sfv是啥类型的文件?