前言
byte就是字节的意思,一个字节就是8个二进制位。uint8,无符号整形,占8位,正好也是2的8次方。所以byte和 uint8 类型本质上没有区别,它表示的是 ACSII 表中的一个字符。
go语言的字符和字节
测试byte和unit8的区别,本身是没有区别的
package main
import "fmt"
func main() {
var x uint8
x = 255
fmt.Println(x)
var y byte
y = 255
fmt.Println(y)
var a byte
a = 'A'
//必须是单引号
fmt.Println(a)
fmt.Printf("%c : %d", a, a)
}
package main
import "fmt"
func main() {
var x uint8
x = 255
fmt.Println(x)
var y byte
y = 255
fmt.Println(y)
var a rune
a = '国'
//rune,占用四个字符,工32位比特位,所以他和int32本质上也没有区别,他表示的是一个unicode字符
fmt.Println(a)
fmt.Printf("%c : %d", a, a)
}
字符串和字节串(熟练掌握)
字节数组,就是一个数组,里面的每一个元素是字符,字符又跟字节划等号,所以字符串和字节串可以相互转换。
字符串与字节串之间的转换
这也是个编码和解码的过程
package main
import (
"fmt"
"reflect"
)
func main() {
var s = "中国"
fmt.Println(s, reflect.TypeOf(s))
// 下面是编码
y := []byte(s)
//[228 184 173 229 155 189]
//中国两个字符,需要六个字节来存储, 中是 228,184,173
fmt.Println(y, reflect.TypeOf(y)) // [] uint8
}
// 下面是解码
fmt.Println(string(b) //中国
执行结果:
字符串的遍历
(2种方式)for 和range
package main
import "fmt"
func main() {
var name = "itlaoxin is me "
for i := 0; i < len(name); i++ {
fmt.Println(name[i]) //这样取出来的是数字
//解码
fmt.Println(string(name[i]))
fmt.Printf("%c"name[i])
}
}
如果name = " i am 老辛" 这种会出现什么问题呢?
答: 这个时候,如果我们用for循环遍历,以为一个中文是三个字符,所以会出现乱码,这时候就需要使用range
方法二:
package main
import "fmt"
func main() {
name := "i am 老辛"
for _, v := range name {
fmt.Println(string(v))
}
}
go语言中的字符串字符不可以修改
package main
import "fmt"
func main() {
name := "i am 老辛"
fmt.Println(name[0])
name[0] = "m" // 可以看到不允许修改
}
}