首页
学习
活动
专区
圈层
工具
发布

CRC32交换
EN

Stack Overflow用户
提问于 2021-05-18 11:13:20
回答 1查看 103关注 0票数 0

我有两个函数来计算CRC32:

1)

代码语言:javascript
复制
for (loop = 0u; loop < len; ++loop)
{
    crc = lut[((uint8_t)(crc >> 24) ^ data[loop])] ^ (crc << 8u);
}

代码语言:javascript
复制
for (i = 0u; i < len; i++)
{
    crc = lut[((uint32_t)data[i] ^ crc) & 0xFFu] ^ (crc >> 8u);
}

两者都可以计算相同的结果,但:

第二个Endianess

  • After表的
  • 查找表具有不同的
  • 计算结果,并交换了

问题是为什么有两个不同的实现?是否有一个特定的名称来计算,如在第二个例子?

EN

回答 1

Stack Overflow用户

发布于 2021-05-18 21:17:04

如果表也是字节交换的,那么在字节交换之后,它们显然是等价的。

通常情况下,我会看到这两种不同的CRC计算形式,因为一种是使用位反射多项式(用>>编写的代码),另一种是使用正常多项式("<<")。

但是,我还没有见过这样的情况:有人拿了其中的一个,然后字节交换了表,并从"<<“切换到">>”,反之亦然。我不认为这有什么名字。

我可以想象的应用程序是,有人必须在最后将结果进行字节交换,以便更容易地将CRC放在某种预定义的格式中,然后他们意识到,如果他们将其内置到表中,并在计算时转换方向,他们就可以避免字节交换。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67585066

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档