给你51单片机 CRC16计算
#include "reg51.h"
/*******************************
冯雪松 已调试校验正确
CRC计算方法
1.预置1个16位的寄存器为十六进制FFFF(即全为1);称此寄存器为CRC寄存器;
2.把第一个8位二进制数据(既通讯信息帧的第一个字节)与16位的CRC寄存器的低
8位相异或,把结果放于CRC寄存器;
3.把CRC寄存器的内容右移一位(朝低位)用0填补最高位,并检查右移后的移出位;
4.如果移出位为0:重复第3步(再次右移一位);
如果移出位为1:CRC寄存器与多项式A001(1010 0000 0000 0001)进行异或;
5.重复步骤3和4,直到右移8次,这样整个8位数据全部进行了处理;
6.重复步骤2到步骤5,进行通讯信息帧下一个字节的处理;
7.将该通讯信息帧所有字节按上述步骤计算完成后,得到的16位CRC寄存器的高、低
字节进行交换;
*///////////////////////////////////////////////////////////////////////////////////
#define uchar unsigned char
#define uint unsigned int
#define ufloat unsigned float
unsigned char a,i;
unsigned char Sdata[6]={01,03,00,01,00,01} ;
unsigned int CRC=0XFFFF;
unsigned char CRC_count;
main()
{ while(1){
for (a=0;a<6;a++){
CRC=CRC^Sdata[a];
for(i=0;i<8;i++)
{
if(CRC&1)
{
CRC>>=1;
CRC^=0XA001;
}
else CRC>>=1;
}
}
}
}