16bit CRC算法C语言实现
#define CRC_16_POLYNOMIALS 0x8005 unsigned short CRC16_3(unsigned char* pchMsg, unsigned short wDataLen) // 1. MSB first; 2. Initial value is 0000; { unsigned char i, chChar; unsigned short wCRC = 0; while (wDataLen--) { chChar = *pchMsg++; wCRC ^= (((unsigned short) chChar) << 8); for (i = 0; i < 8; i++) { if (wCRC & 0x8000) wCRC = (wCRC << 1) ^ CRC_16_POLYNOMIALS; else wCRC <<= 1; } } return wCRC; }
备注:多项式0x8005的含义是: x^15 + x^2 + 1
版权声明:
作者:朝雾之归乡
出处:http://www.cnblogs.com/cnpirate
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利。