Go语言字符串中的字符有英文字符、数字、中文字符等等,Go语言处理纯英文数字字符串可以使用byte类型
1.byte类型
byte类型 是 uint8的别名,表示一个字节
2.rune类型
rune类型是Go语言中的一个基本类型,其实是一个int32的别名,主要用于表示一个字符类型大于一个字节小于等于4个字节的情况下,特别是中文字符,rune类型的值与Unicode码点一一对应。
下面的代码可以看出这两个类型的区别:
import "fmt"
func main(){
var str string="123中国"
fmt.Println("byte=",[]byte(str))
fmt.Println("byte=",[]rune(str))
fmt.Println(str[:4])
fmt.Println(string([]byte(str)[:4]))
fmt.Println(string([]rune(str)[:4]))
}
执行结果:
byte类型在处理多字节字符时,会出现乱码, 而rune类型可以正常处理。
var str string = "123中国"
bytes := []byte(str)
bytes[0] = '中' // 程序爆红 不能编译
str = string(bytes)
fmt.Printf("%s\n", str)
由上面的代码可以看到,字符串byte类型转化后,赋于多字节字符会报错。
var str string = "123看中国"
runes := []rune(str)
runes[3] = '大'
str = string(runes)
fmt.Printf("%s\n", str) // 123大中国
程序运行正常