在Go中,如果我从字符串-> [] byte转换,或者相反,从[] byte->字符串转换,数据可能会损坏。例如,假设我已定义:
fooBytes := []byte(fooString)
fooConvertedBack := string(fooBytes
fooBytesConvertedBack := []byte(fooConvertedBack)
然后我们可以得到数据损坏的情况:
fooString != fooConvertedBack
fooBytes != fooBytesConvertedBack
我猜这里的答案是否定的。我正在使用字节的随机数组,因此我想确保不会破坏数据,因为例如golang字符串具有默认字符集,该字符集不允许完全随机的字节。
base64编码字节更好吗?
最佳答案
正如CeriseLimón所写,它不会被损坏。在string
和[]byte
之间转换不会解释字节,而只是按原样复制它们。
但是请注意,如果要在string
和[]rune
之间转换,则可能会更改内容,如Spec: Conversions to and from a string type所示:
将字符串类型的值转换为符文类型的 slice 会产生一个 slice ,其中包含字符串的各个Unicode代码点。
因此,此转换将对符文(Unicode代码点)进行解码,并且如果输入的string
不是有效的UTF-8编码文本,则在这种情况下将使用Unicode替换字符0xFFFD
。
例如,包含单个string
字节的0xff
不是有效的UTF-8编码文本:
fooString := "\xff"
barString := string([]rune(fooString))
fmt.Println(fooString == barString)
fmt.Printf("%x %x", fooString, barString)
输出(在Go Playground上尝试):
false
ff efbfbd
(注意:十六进制
efbfdb
是Unicode替换字符0xFFFD
的3字节UTF-8编码值。)