C++ 实现 CRC-32 校验算法
以下是 C++ 实现的 CRC-32 校验程序示例:
#include <iostream>
#include <cstdint>
uint32_t crc32(const uint8_t *buf, uint32_t len) {
uint32_t crc = 0xffffffff;
for (uint32_t i = 0; i < len; i++) {
crc ^= buf[i];
for (uint32_t j = 0; j < 8; j++) {
crc = (crc >> 1) ^ (0xEDB88320 & -(crc & 1));
}
}
return ~crc;
}
int main() {
uint8_t buf[] = '123456789';
uint32_t crc = crc32(buf, sizeof(buf)-1);
std::cout << std::hex << crc << std::endl;
return 0;
}
该程序实现了一个基于 CRC-32 算法的校验器,并可以计算给定数据的 CRC 校验码。其中,crc32 函数接收一个指向数据缓冲区的指针和缓冲区长度,返回计算得到的 CRC 校验码。该函数的实现采用了标准的 CRC-32 算法,具体实现方式可以参考 这里。
在主函数中,我们声明了一个待校验的数据缓冲区 buf,并调用 crc32 函数计算出它的 CRC 校验码。最后,我们将计算得到的结果打印出来,以 16 进制形式输出。注意,由于数据缓冲区末尾有一个 NULL 终止符,因此在计算时需要减去 1。
原文地址: https://www.cveoy.top/t/topic/nCS0 著作权归作者所有。请勿转载和采集!