最近用到CRC校验算法,就找了些资料,学习了一下,网上关于CRC32的资料也多,但感觉不是很完整,或者太高深。
CRC算法查表法很常见,但表是怎么来的,有些资料说得不很清楚。
我来说一下我的看法:
1.CRC校验变化太多,有CRC4/5/6/7/8/16/32,每一种的多项式也有很多种变化,并不是一成不变的;
2.输入输出方式也有区别,有一些初始值是0,有一些初始值是0xFFFFFFFF,有一些直接返回,有一些异或返回。
因此,CRC校验很难用一个代码兼容全部,只能根据项目需要修改相关参数了。
计算方法:
1.先要知道多项式是什么样子,以这个IEEE802.3标准CRC32多项式为例:<