我有一個(gè)字節(jié) 0x38b:= 0x38
fmt.Printf("%b\n",b)二進(jìn)制是 00111000。我怎樣才能得到這個(gè)的一個(gè)子集作為一個(gè)新的int?例如,我想要位 7,6,5,在這種情況下將是 int(1)?;蛭?3,2,1 將是 int(4)
2 回答

鳳凰求蠱
TA貢獻(xiàn)1825條經(jīng)驗(yàn) 獲得超4個(gè)贊
一種更通用的方法可以讓您選擇無序位,如下所示:
// 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)
}

富國滬深
TA貢獻(xiàn)1790條經(jīng)驗(yàn) 獲得超9個(gè)贊
要獲得高位,您可以將值向右移動(dòng)
bits765 := b >> 5
要獲得中間的位,您可以移動(dòng)它們?nèi)缓笃帘尾恍枰奈唬?/p>
bits321 := (b >> 1) & 7
- 2 回答
- 0 關(guān)注
- 209 瀏覽
添加回答
舉報(bào)
0/150
提交
取消