crc16校验c语言实现
时间: 2023-08-23 22:05:48 浏览: 87
下面是一个简单的实现:
```c
#include <stdio.h>
#define POLY 0x1021 // CRC-16-CCITT polynomial
#define INIT 0xFFFF // initial value of CRC register
unsigned short crc16(unsigned char *data, int len) {
unsigned short crc = INIT;
int i, j;
for (i = 0; i < len; i++) {
crc ^= (unsigned short)data[i] << 8;
for (j = 0; j < 8; j++) {
if (crc & 0x8000) {
crc = (crc << 1) ^ POLY;
} else {
crc <<= 1;
}
}
}
return crc;
}
int main() {
unsigned char data[] = {0x01, 0x02, 0x03, 0x04};
int len = sizeof(data) / sizeof(data[0]);
unsigned short result = crc16(data, len);
printf("CRC-16: 0x%04X\n", result);
return 0;
}
```
其中,`POLY` 定义了校验码的多项式,`INIT` 定义了 CRC 寄存器的初始值。
函数 `crc16` 接收一个 `unsigned char` 类型的指针和一个 `int` 类型的长度参数,返回一个 `unsigned short` 类型的校验码。
在主函数中,我们通过定义一个 `unsigned char` 类型的数组 `data` 来模拟待校验的数据,然后调用 `crc16` 函数得到校验码并输出。
阅读全文