首页 > 编程知识 正文

byte数组转string不完整,byte数组转string中文乱码

时间:2023-05-03 15:12:36 阅读:286330 作者:1886

通常我们将一个[]byte类型或[]uint8类型的变量通过string()可以直接转化成一个字符串,但是下面的示例却转化的不如预期:

package mainimport "fmt"func main() {a := []byte{2, 3, 6, 2}fmt.Println("strA :", string(a)) //strA : ╗╚═╗}

与期望得到的字符串"2362"有差别,为什么会出现这种情况呢?原因在于在Go中,字符串值表示了一个字符值的集合。在底层,一个字符串值即一个包含了若干个字节的序列。长度为0的序列与一个空字符串相对应,字符串的长度即底层字节序列中字节的个数。
使用string()方法来转化[]byte类型或[]uint8类型的变量,其实就是将编码后的值转化成字面量上的值。所以上面的2,3,6,2就变成了看不懂的符号。当我们将变量a中的值替换成2,3,6,2对应的utf-8编码时,就能正常得到结果。

package mainimport "fmt"func main() { a := []byte{50, 51, 54, 50} fmt.Println("strB :", string(a)) //strB : 2362}

那么,当是第一个示例中的变量a那样,怎么得到一个字符串类型的2362呢,这就是今天讨论的。

package mainimport ("fmt""strconv")func main() {a := []byte{2, 3, 6, 2}var c stringfor _, value := range a {c = c + strconv.Itoa(int(value))}fmt.Println("c :", c)}

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。