通信协议 CRC校验和计算方法

来源:互联网 发布:centos安装pptp 编辑:程序博客网 时间:2024/05/29 17:38
 
 public static uint CalCrc16(byte[] buf, int start, int end)        {            byte CRC16Lo, CRC16Hi;   //CRC寄存器            byte CL, CH;             //多项式码&HA001            byte SaveLo, SaveHi;            int i, Flag;            CRC16Hi = 0xFF;            CRC16Lo = 0xFF;            CL = 0x1;            CH = 0xA0;            for (i = start; i <= end; i++)            {                CRC16Lo = (byte)(CRC16Lo ^ buf[i]); //每一个数据与CRC寄存器进行异或                for (Flag = 0; Flag <= 7; Flag++)                {                    SaveHi = CRC16Hi;                    SaveLo = CRC16Lo;                    CRC16Hi = (byte)(CRC16Hi / 2);             //高位右移一位                    CRC16Lo = (byte)(CRC16Lo / 2);             //低位右移一位                    if ((SaveHi & 0x1) == 0x1)                    {                        CRC16Lo = (byte)(CRC16Lo | 0x80);                    }                    if ((SaveLo & 0x1) == 0x1)                    {                        CRC16Hi = (byte)(CRC16Hi ^ CH);                        CRC16Lo = (byte)(CRC16Lo ^ CL);                    }                }            }            return (uint)CRC16Hi * 256 + CRC16Lo;        }

原创粉丝点击