码迷,mamicode.com
首页 > 编程语言 > 详细

CRC32算法笔记

时间:2018-04-15 18:47:43      阅读:230      评论:0      收藏:0      [点我收藏+]

标签:dmi   技术   standard   实现   tle   www.   bdd   cli   代码   

这几天在研究CRC32的计算过程,看了CRC算法的原理,也看了不少通过移位法实现的代码,但是算出的结果跟校验工具算的不一致。

折腾了好长时间,终于找到一个手工计算CRC32的文章,再对照IEEE 802.3标准的CRC计算过程,才算把CRC32的计算搞定。

这里把计算过程的要点记录一下:

1) CRC32是CRC算法一种,先参考Wiki上CRC算法的原理和实例搞明白基本的计算方法。

2) 最常见的CRC32算法就是IEEE 802.3里生成FCS字段用的那个:

a) CRC32使用的Polynomial是 技术分享图片

b) IEEE 802.3在传送数据时使用的是最低有效位优先 (least significant bit first),所以要根据你机器的架构转换成有效的比特流输入。同理,输出流也一样。

c) 为了有效识别输入流开头和结尾的零,开头的32位要按位取反(complement),最后计算出的余数也要按位取反。

按照上述方法计算能得到想要的CRC32值了。

CRC32算法笔记

标签:dmi   技术   standard   实现   tle   www.   bdd   cli   代码   

原文地址:https://www.cnblogs.com/LikeVirgo/p/8848583.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!