CRC16 的生成及校验原理「建议收藏」

CRC16 的生成及校验原理「建议收藏」参考:https://blog.csdn.net/niepangu/article/details/45499383计算CRC的过程,就是用一个特殊的“除法”,来得到余数,这个余数就是CRC。&#1

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

参考:https://blog.csdn.net/niepangu/article/details/45499383

 

计算CRC的过程,就是用一个特殊的“除法”,来得到余数,这个余数就是CRC。 
它不是真正的算术上的除法!过程和算术除法过程一样,只是加减运算变成了XOR(异或)运算! 
 
算术上的除法: 
120÷9=13 余 3,120是被除数,9是除数,13是商,3是余数。念作120除以9,或者9除120,或
者9去除120!(除法的过程就不写了) 
这个除法计算机当然会做,但是做起来很麻烦,因为减法有借位,很耗时间和指令! 
所以,计算CRC也是除法,但是用XOR来代替减法,这就简单多了!

CRC的除法: 
120÷9=14 余 6,商、余数和算术除法不一定相同!!因为除法用的是XOR,而不是真正的减法。 
以二进制模拟这个计算过程: 

120 二进制:1111000 、除数9 二进制:1001 、商 14 二进制:1110 余数6 二进制:110 

从高位1111开始,每次进行一次XOR 的到的值后,去掉最高位加入下一位,每加一次进行一次XOR运算。

  1111

^1001

————– 

  0110

 第一次XOR后得到0110,去掉最高位0,加入下一位0, 得1100 ,这样最高位是1,所以下个商是1 ,用^1001【很明显保留的位数与1001 保持一致】

  1100

^1001

————–

   0101

第二次XOR ,去掉最高位,加入下一位0,得1010 ,这样最高位是1,所以下个商是1 ,用^1001

  1010

^ 1001

—————

  0011

第三次XOR,去掉最高位,加入下一位0,得0110 ,这样最高位是1,所以下个商是0 ,用^0000

  0110

^ 0000

————-

  0110

最后一次XOR后得到0110,最高位的0可以消掉了,得到余数为110,即6 
注意,余数不是0110,而是110,因为最前面那个0已经被XOR后消掉了!

 

 

可见,除法(XOR)的目的是逐步消掉最高位的1或0! 
由于过程是XOR的,所以商是没有意义的,我们不要。我们要的是余数。 
 
余数110是1111000的CRC吗?不是! 
余数110是1111(即十进制15)的CRC!!! 
为什么?因为CRC是和数据一起传送的,所以数据后面要加上CRC。 
数据1111加上CRC110后,变成1111110,再传送。接收机收到1111110后,除以除数1001,余数为
000,正确;如果余数不为0,则说明传送的数据有误!这样完成CRC校验。 
即发送端要发送1111,先在1111后加000,变成1111000,再除以1001得到余数110,这个110
就是CRC,将110加到数据后面,变成1111110,发送出去。 
接收端收到1111110,用它除以1001,计算得余数为000,就说明收到的数据正确。 
所以原始数据后面要先扩展出3位0,以容纳CRC值! 
会发现,在上面的除法过程中,这3位0,能保证所有的4个数据位在除法时都能够被处理到!不然做
一次除法就到结果了,那是不对的。这个概念后面要用到。 

 

二、  生成项 
上面例子中,生成项是1001,共4位比特,最高位的1,实际上在除法的每次XOR时,都要消掉,所
以这个1可不做参考,后3位001才是最重要的!001有3位,所以得到的余数也是3位,因为最后一次除
法XOR时,最高位消掉了。所以CRC就是3位比特的。 
CRC是3比特,表示它的宽度W=3。也就是说,原始数据后面要加上W=3比特的0进行扩展! 
生成项的最低位也必须是1,这是规定的。 
生成项1001,就等效于g(x)=x2+1 
生成项也可以倒过来写,即颠倒过来,写成1001,这里倒过来的值是一样的。 
 
再如CRC32的生成项是: 
1 0000 0100 1100 0001 0001 1101 1011 0111  (33个比特) 
即g(x)= x32+x26+x23+x22+x16+x12+x11+x10+x8+x7+x5+x4+x2+x+1 
颠倒过来,就可以写成1110 1101 1011 1000 1000 0011 0010 0000 1 
一般生成项简写时不写最高位的1,故生成项是0x04C11DB7,颠倒后的生成项是0xEDB88320 
CRC32的生成项是33比特,最高位是消掉的,即CRC值是32比特(4个字节),即宽度W=32,就是说,
在计算前,原始数据后面要先扩展W=32个比特0,即4个0x00字节。 
 
注意:我看到网上CRC32的POLY有0x04C10DB7这个值的,它和正规的POLY值不同,需要注意! 
 
颠倒过来,即是镜像,为什么要颠倒,后述。 

拿运 CRC CCITT-16 为例子,行下面的代码,CRC_acc = 0xFFFF;CRC_input[0] = 0x63; 返回校验值CRC.

unsigned short UpdateCRC(unsigned short CRC_acc, unsigned char *CRC_input, unsigned int len)
{
	unsigned char i,k = 0; 
	#define POLY_  0x1021
	while (len--)
	{
		CRC_acc = CRC_acc ^ (CRC_input[k++] << 8);
		printf("CRC_input:%d   : %s\n", CRC_input[0], itoa(CRC_input[0], binbuf, 2));
		printf("CRC_input:%x :%s\n", CRC_acc, itoa(CRC_acc, binbuf, 2));
		printf("POLY_    :%x :%s\n\n", POLY_, itoa(POLY_, binbuf, 2));
		printf("\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\n");
		for (i = 0; i < 8; i++)
		{
			if ((CRC_acc & 0x8000) == 0x8000)
			{
				printf("chushi   :%x    :%s\n", 0, itoa(CRC_acc, binbuf, 2));
				CRC_acc = CRC_acc << 1;
				printf("you yi   :%x    :%s\n", 0, itoa(CRC_acc, binbuf, 2));
				CRC_acc ^= POLY_;
				printf("POLY_1   :%x    :%s\n\n", 0, itoa(CRC_acc, binbuf, 2));
			}
			else
			{
				printf("chushi   :%x    :%s\n", 0, itoa(CRC_acc, binbuf, 2));
				CRC_acc = CRC_acc << 1;
				printf("POLY_0   :%x    :%s\n\n", 0, itoa(CRC_acc, binbuf, 2));
			}
		}
	}
	return CRC_acc;
}

  CRC16 的生成及校验原理「建议收藏」

CRC16 的生成及校验原理「建议收藏」

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/167917.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 中国it人物_计算机界的名人

    中国it人物_计算机界的名人2006.9.2 07:19早起者并不一定收获最多,但成功者一定是方向对,善管理风险的人。  不管是寿国梁、曹军这样的无奈者,还是张树新、王峻涛这样的迷失者,其先发优势都已消失殆净。  从“先驱”到“先烈”的转变,折射出的是市场的易变性和持续成功的“无规律性”。这种“无规律性”既表现在你所需要坚持的东西上,也表现在日常的经营管理中。  8848

    2022年8月30日
    5
  • Java课程设计-学籍信息管理系统「建议收藏」

    一、系统分析    学生的学籍信息是记录学生的重要信息档案,如何以电子文档形式记录下学生的学籍信息是每个学校必须做的事情,该学生学籍信息管理系统就是为了方便学校记录下每一个学生的基本信息,生成电子数据库,并且能够做到查询、更改、删除、浏览等功能操作,让学籍信息的管理更加方便快捷。二、设计方案1、系统框架    学籍信息管理系统是集学籍信息录入,学籍信息查询,学籍

    2022年4月6日
    38
  • 2021年软件测试面试题大全[通俗易懂]

    简述测试流程:1、阅读相关技术文档(如产品PRD、UI设计、产品流程图等)。 2、参加需求评审会议。 3、根据最终确定的需求文档编写测试计划。 4、编写测试用例(等价类划分法、边界值分析法等)。 5、用例评审(主要参与人员:开发、测试、产品、测试leader)。 6、开发提交代码至SVN或者GIT,配管搭建测试环境。 7、执行测试用例,记录发现的问题。 8、验证bug与回归测试。 9、编写测试报告。 10、产品上线。补充测试用例设计过程:根据需求得出测试需求设计测试方

    2022年4月7日
    44
  • pg数据库杀进程_杀掉tomcat进程

    pg数据库杀进程_杀掉tomcat进程pg_cancel_backend()只能关闭当前用户下的后台进程向后台发送SIGINT信号,用于关闭事务,此时session还在,并且事务回滚pg_terminate_backend()需要superuser权限,可以关闭所有的后台进程向后台发送SIGTERM信号,用于关闭事务,此时session也会被关闭,并且事务回滚…

    2022年9月5日
    6
  • 数据结构中的elemtype、elem是什么

    数据结构中的elemtype、elem是什么ElemType是数据结构的书上为了说明问题而用的一个词。它是elementtype(“元素的类型”)的简化体。 因为数据结构是讨论抽象的数据结构和算法的,一种结构中元素的类型不一定是整型、字符型、浮点型或者用户自定义类型,为了不重复说明,使用过程中用“elemtype”代表所有可能的数据类型,简单明了的概括了整体。在算法中,除特别说明外,规定ElemType的默认是int型。elem是单词…

    2022年5月19日
    55
  • iPhone 抓包工具Charles使用[通俗易懂]

    iPhone 抓包工具Charles使用[通俗易懂]Charles是在Mac下常用的截取网络封包的工具,在做iOS开发时,我们为了调试与服务器端的网络通讯协议,常常需要截取网络封包来分析。Charles通过将自己设置成系统的网络访问代理服务器,使得所有的网络访问请求都通过它来完成,从而实现了网络封包的截取和分析。Charles主要的功能包括:支持SSL代理。可以截取分析SSL的请求。支持流量控制。可以模拟慢速网络

    2022年5月16日
    543

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号