Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/wpf/12.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Go 如何从一个字节中得到一个子集?_Go - Fatal编程技术网

Go 如何从一个字节中得到一个子集?

Go 如何从一个字节中得到一个子集?,go,Go,我有一个字节0x38 b:= 0x38 fmt.Printf("%b\n",b) 二进制的00111000 我怎样才能得到一个子集作为一个新的int? 例如,我想要位7,6,5,在本例中为int(1)。 或位3,2,1,它将是int(4)要获得高位,您可以将值向右移位 bits765 := b >> 5 为了在中间获得位,可以移动它们,然后屏蔽不需要的位: bits321 := (b >> 1) & 7 要获取高位,可以将值向右移动 bits765 := b

我有一个字节0x38

b:= 0x38
fmt.Printf("%b\n",b)
二进制的00111000

我怎样才能得到一个子集作为一个新的int? 例如,我想要位7,6,5,在本例中为int(1)。
或位3,2,1,它将是int(4)

要获得高位,您可以将值向右移位

bits765 := b >> 5

为了在中间获得位,可以移动它们,然后屏蔽不需要的位:

bits321 := (b >> 1) & 7

要获取高位,可以将值向右移动

bits765 := b >> 5

为了在中间获得位,可以移动它们,然后屏蔽不需要的位:

bits321 := (b >> 1) & 7

允许您选择无序位的更通用方法如下:

// 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)
}
//子集必须从最低到最高
函数位(b单元,子集…单元)(r单元){
i:=uint(0)
对于v,v:=范围子集{
如果b&(1>1)&7)
}

请记住,对于顺序子集,@Guffa的解决方案要快得多。

一种更通用的方法可以让您选择无序位,它类似于:

// 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)
}
//子集必须从最低到最高
函数位(b单元,子集…单元)(r单元){
i:=uint(0)
对于v,v:=范围子集{
如果b&(1>1)&7)
}

请记住,对于顺序子集,@Guffa的解决方案要快得多。

我认为
bool
是一个输入错误,应该是
uint8
。上档原因位算术检查。我认为
bool
是一个输入错误,应该是
uint8
。上档原因位算术检查。