1
我有一個字節0x38我如何獲得一個字節的位的子集?
b:= 0x38
fmt.Printf("%b\n",b)
這是二進制00111000。
我怎樣才能得到這個作爲一個新的int的子集? 例如,我想要位7,6,5,在這種情況下將是int(1)。 或位3,2,1,這將是int(4)
我有一個字節0x38我如何獲得一個字節的位的子集?
b:= 0x38
fmt.Printf("%b\n",b)
這是二進制00111000。
我怎樣才能得到這個作爲一個新的int的子集? 例如,我想要位7,6,5,在這種情況下將是int(1)。 或位3,2,1,這將是int(4)
一個更通用的方法,將允許您挑選無序位會是這樣的:
// subset has to go from lowest to highest
func bits(b uint, subset ...uint) (r uint) {
i := uint(0)
for _, v := range subset {
if b&(1<<v) > 0 {
r = r | 1<<uint(i)
}
i++
}
return
}
func main() {
fmt.Println(bits(0x38, 5, 6, 7), "x", 0x38>>5)
fmt.Println(bits(0x38, 2, 4, 5))
fmt.Println(bits(0x38, 1, 2, 3), "x", (0x38>>1)&7)
}
請記住,對於順序子集,@ Guffa的解決方案要快得多。
要獲得高位也可以將該值
bits765 := b >> 5
右移要在中間得到位,你可以將它們轉移和然後屏蔽掉不需要的位:
bits321 := (b >> 1) & 7
我覺得'bool'是一個錯字,應該是'uint8'。 upvoted原因位算術檢查。 – thwd 2014-09-26 23:40:07