[Linux]CRC校验

来源:互联网 发布:淘宝客服人工服务在线 编辑:程序博客网 时间:2024/06/06 00:37

CRC(Cyclic Redundancy Check),循环冗余校验码,是数据通信领域中最常用的一种差错校验码,其特征是信息字段和校验字段的长度可以任意选定。

CRC校验步骤:

CRC分为两部分,前部分为信息码,后部分为校验码;设信息码为K(x),为k-1次幂多项式,生成校验多项式为R(x),为R-1次幂多项式。(1)首先将原信息多项式左移R-1位。(2)通过生成多项式码模2除原信息码,得到的余数与原信息码最终得到CRC校验码

举个栗子:

信息码对应的多项式为x6+x4+x3+1(1011001),生成多项式g(x)=x4+x3+1(11001)的CRC。

这里写图片描述

此时余数是1010,所以CRC校验码为:10110011010。