概述
倡议先浏览 字符串, 切片 两个大节。
因为字符串不可变,如果每次以 从新赋值
的形式扭转字符串,效率会非常低,这时应该应用 []byte
类型,[]byte 元素能够被批改。
因为 byte
类型是 uint8
类型的别名,所以 []byte
也就是 []uint8
。
语法规定
字符串转化为 []byte
package main
import "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 main
import "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 main
import "fmt"
func main() {b := []byte{'h', 'i'}
fmt.Printf("b length = %d\n", len(b))
}
// $ go run main.go
// 输入如下
/**
b length = 2
*/
中文算作 3 个字符
package main
import "fmt"
func main() {b := []byte("我是")
fmt.Printf("b length = %d\n", len(b))
}
// $ go run main.go
// 输入如下
/**
b length = 6
*/
中文算作 1 个字符
package main
import (
"fmt"
"unicode/utf8"
)
func main() {b := []byte("我是")
fmt.Printf("b length = %d\n", utf8.RuneCount(b))
}
// $ go run main.go
// 输入如下
/**
b length = 2
*/
扩大浏览
- 十分钟搞清字符集和字符编码