我如何获得一个字节的位的子集?

问题描述:

我有一个字节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的解决方案要快得多。

+0

我觉得'bool'是一个错字,应该是'uint8'。 upvoted原因位算术检查。 – thwd 2014-09-26 23:40:07

要获得高位也可以将该值

bits765 := b >> 5 

右移要在中间得到位,你可以将它们转移和然后屏蔽掉不需要的位:

bits321 := (b >> 1) & 7