概述

倡议先浏览 字符串, 切片 两个大节。

因为字符串不可变,如果每次以 从新赋值 的形式扭转字符串,效率会非常低,这时应该应用 []byte 类型,[]byte 元素能够被批改。

因为 byte 类型是 uint8 类型的别名,所以 []byte 也就是 []uint8

语法规定

字符串转化为 []byte

package mainimport "fmt"func main() {    s := "hello world"    b := []byte(s)    fmt.Printf("b type = %T, val = %s\n", b, b)}// $ go run main.go// 输入如下/**  b type = []uint8, val = hello world*/

[]byte 转换为字符串

package mainimport "fmt"func main() {    b := []byte{'h', 'e', 'l', 'l', '0', ' ', 'w', 'o', 'r', 'l', 'd'}    s := string(b)    fmt.Printf("s type = %T, val = %s\n", s, s)}// $ go run main.go// 输入如下/**  s type = string, val = hell0 world*/

长度计算

对于字符串不同编码对长度的计算形式,感兴趣的读者能够参考扩大浏览。

ASCII

package mainimport "fmt"func main() {    b := []byte{'h', 'i'}    fmt.Printf("b length = %d\n", len(b))}// $ go run main.go// 输入如下/**  b length = 2*/

中文算作 3 个字符

package mainimport "fmt"func main() {    b := []byte("我是")    fmt.Printf("b length = %d\n", len(b))}// $ go run main.go// 输入如下/**  b length = 6*/

中文算作 1 个字符

package mainimport (    "fmt"    "unicode/utf8")func main() {    b := []byte("我是")    fmt.Printf("b length = %d\n", utf8.RuneCount(b))}// $ go run main.go// 输入如下/**  b length = 2*/

扩大浏览

  1. 十分钟搞清字符集和字符编码

分割我