我有一个 UInt8
数组,我想计算 CheckSum8 模 256。
如果字节总和小于 255,checkSum
函数返回正确的值。
例如
let bytes1 : [UInt8] = [1, 0xa1]
let validCheck = checkSum(data : bytes1) // 162 = 0xa2
let bytes : [UInt8] = [6, 0xB1, 27,0xc5,0xf5,0x9d]
let invalidCheck = checkSum(data : bytes) // 41
下面的函数返回 41,但预期校验和为 35。
func checkSum(data: [UInt8]) -> UInt8 {
var sum = 0
for i in 0..<data.count {
sum += Int(data[i])
}
let retVal = sum & 0xff
return UInt8(retVal)
}
最佳答案
您的checkSum
方法基本上是正确的。如果需要,您可以将其简化为:
func checkSum(_ values: [UInt8]) -> UInt8 {
let result = values.reduce(0) { ($0 + UInt32($1)) & 0xff }
return UInt8(result)
}
您指出一个网站报告 06B127c5f59d
的校验和 8 为 35
。
问题是您的数组中有 27
,而不是 0x27
。如果您有十六进制值,则数组字面量中的每个值始终需要 0x
前缀(或者,从技术上讲,至少在值大于 9
时)。
所以,考虑:
let values: [UInt8] = [0x06, 0xB1, 0x27, 0xc5, 0xf5, 0x9d]
let result = checkSum(values)
那是 53
。如果您想以十六进制形式查看(例如您提到的那个网站):
let hex = String(result, radix: 16)
这表明校验和是十六进制的 0x35
。
关于swift - CheckSum8 模 256 Swift,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54935688/