我实现了我发现的这个校验和算法,它工作正常,但我无法弄清楚这条“&= 0xFF”行实际上在做什么。
我查找了按位 & 运算符,维基百科声称它是 A 和 B 中所有位的逻辑与。我还读到 0xFF 相当于 255——这应该意味着所有位都是 1。如果你取任何数字& 0xFF,那不是数字的标识吗?所以 A & 0xFF 产生 A,对吗?
然后我想,等一下,下面代码中的校验和是一个 32 位的 Int,但是 0xFF 是 8 位的。这是否意味着 checksum &= 0xFF 的结果是 24 位最终为零,只保留剩余的 8 位?在这种情况下,校验和被截断为 8 位。这就是这里发生的事情吗?
private int CalculateChecksum(byte[] dataToCalculate)
{
int checksum = 0;
for(int i = 0; i < dataToCalculate.Length; i++)
{
checksum += dataToCalculate[i];
}
//What does this line actually do?
checksum &= 0xff;
return checksum;
}
此外,如果结果被截断为 8 位,那是因为 32 位在校验和中毫无意义吗?是否可能出现 32 位校验和捕获损坏数据而 8 位校验和未捕获损坏数据的情况?
最佳答案
它屏蔽掉了高位字节,只留下低位字节。
checksum &= 0xFF;
语法上的缩写:
checksum = checksum & 0xFF;
其中,由于它正在执行整数运算,因此 0xFF
被扩展为 int
:
checksum = checksum & 0x000000FF;
它屏蔽掉高 3 个字节并将低字节作为整数(不是字节)返回。
回答您的另一个问题:由于 32 位校验和比 8 位校验和宽得多,它可以捕获 8 位校验和不会捕获的错误,但双方都需要为此使用相同的校验和计算上类。
关于c# - 校验和中的 "int &= 0xFF"有什么作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49778347/