我具有将字节数组转换为代表0和1的布尔数组的功能:
func byteArrayToBoolArray(ba []byte) []bool {
var s []bool
for _, b := range ba {
for _, c := range strconv.FormatUint(uint64(by), 2) {
s = append(s, c == []rune("1")[0])
}
}
return s
}
一个函数的外观正好相反,意味着将布尔数组转换为字节数组?
编辑:这个游乐场提供了更多详细信息,我的字节数组可能是这样的:https://play.golang.org/p/tEDcZv-t_0Q
ba := []byte{123, 255}
答案 0 :(得分:1)
例如boolsToBytes
,bytesToBools
的倒数(恰好相反),
package main
import (
"fmt"
)
func boolsToBytes(t []bool) []byte {
b := make([]byte, (len(t)+7)/8)
for i, x := range t {
if x {
b[i/8] |= 0x80 >> uint(i%8)
}
}
return b
}
func bytesToBools(b []byte) []bool {
t := make([]bool, 8*len(b))
for i, x := range b {
for j := 0; j < 8; j++ {
if (x<<uint(j))&0x80 == 0x80 {
t[8*i+j] = true
}
}
}
return t
}
func main() {
b := []byte{123, 255}
fmt.Println(b)
t := bytesToBools(b)
fmt.Printf("%t\n", t)
b = boolsToBytes(t)
fmt.Println(b)
}
游乐场:https://play.golang.org/p/IguJ_4cZKtA
输出:
[123 255]
[false true true true true false true true true true true true true true true true]
[123 255]
问题提供了一个功能,并要求一个反函数(正好相反)。
问题函数算法有缺陷,多个输入映射到相同的函数值。因此,没有唯一的逆。
package main
import (
"fmt"
"strconv"
)
func byteArrayToBoolArray(ba []byte) []bool {
var s []bool
for _, b := range ba {
for _, c := range strconv.FormatUint(uint64(b), 2) {
s = append(s, c == []rune("1")[0])
}
}
return s
}
func main() {
ba1 := []byte{0xF}
fmt.Println(byteArrayToBoolArray(ba1))
ba2 := []byte{0x3, 0x3}
fmt.Println(byteArrayToBoolArray(ba2))
ba3 := []byte{0x1, 0x1, 0x1, 0x1}
fmt.Println(byteArrayToBoolArray(ba3))
}
游乐场:https://play.golang.org/p/L9VsTtbkQZW
输出:
[true true true true]
[true true true true]
[true true true true]