110,536
社区成员
发帖
与我相关
我的任务
分享
/// <summary>
/// 将字节数组进行CRC16验证,多项式:A001
/// </summary>
/// <param name="data"></param>
/// <returns></returns>
public static byte[] CRC16_2(byte[] data) {
byte[] returnVal = new byte[2];
byte CRC16Lo, CRC16Hi, CL, CH, SaveHi, SaveLo;
int i, Flag;
CRC16Lo = 0xFF;
CRC16Hi = 0xFF;
CL = 0x01;
CH = 0xA0;
for (i = 0; i < data.Length; i++) {
CRC16Hi = (byte)(CRC16Hi ^ data[i]);//每一个数据与CRC寄存器进行异或
for (Flag = 0; Flag <= 7; Flag++) {
SaveHi = CRC16Hi;
SaveLo = CRC16Lo;
CRC16Hi = (byte)(CRC16Hi >> 1);//高位右移一位
CRC16Lo = (byte)(CRC16Lo >> 1);//低位右移一位
if ((SaveHi & 0x01) == 0x01)//如果高位字节最后一位为1
{
CRC16Lo = (byte)(CRC16Lo | 0x80);//则低位字节右移后前面补1 否则自动补0
}
if ((SaveLo & 0x01) == 0x01)//如果LSB为1,则与多项式码进行异或
{
CRC16Hi = (byte)(CRC16Hi ^ CH);
CRC16Lo = (byte)(CRC16Lo ^ CL);
}
}
}
returnVal[1] = CRC16Hi;//CRC高位
returnVal[0] = CRC16Lo;//CRC低位
return returnVal;
}