从 Go 中的字节中获取位
要从 Go 中的字节中提取各个位,可以考虑多种方法。
视觉表示:
对于位的视觉表示,您可以使用 fmt.Sprintf(" b", ...) 以二进制格式打印字节.
按位运算:
但是,如果您需要使用位进行诸如计算汉明距离之类的操作,则需要使用按位运算符。
要检索字节的第 n 位,请按位与该字节与掩码,其中第 n 位设置为 1,其余设置为 0(即 2 的幂)。例如,要查找字节 13 的第 1 位 (00001101),请用 1 (00000001) 对其进行掩码。如果按位与的结果等于掩码,则第 n 位为 1。
示例代码:
<code class="go">fmt.Print(13 & 1) // Output: 1 (1st bit) fmt.Print(13 & 2) // Output: 0 (2nd bit) fmt.Print(13 & 4) // Output: 4 (3rd bit) fmt.Print(13 & 8) // Output: 8 (4th bit)</code>
汉明距离计算:
要计算两个字节之间的汉明距离,请使用按位与运算来比较相应位。如果结果位为 1,则表明这些位不同,并且您增加距离计数。
<code class="go">diff := 0 mask := byte(1 << uint(j)) if (b1 & mask) != (b2 & mask) { diff++ }</code>
汉明距离函数:
这是一个用于计算两个字节数组之间的汉明距离的示例函数:
<code class="go">func hamming(a, b []byte) (int, error) { ... for j := 0; j < 8; j++ { mask := byte(1 << uint(j)) if (b1 & mask) != (b2 & mask) { diff++ } } ... }</code>
此函数比较数组中相应字节的位,并递增每个不同位的距离计数。
以上是如何在 Go 中从字节中提取各个位?的详细内容。更多信息请关注PHP中文网其他相关文章!