0
点赞
收藏
分享

微信扫一扫

go语言基础语法- 字符和字节-字符串


前言

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)
}

go语言基础语法- 字符和字节-字符串_for循环

字符串和字节串(熟练掌握)

字节数组,就是一个数组,里面的每一个元素是字符,字符又跟字节划等号,所以字符串和字节串可以相互转换。

字符串与字节串之间的转换

这也是个编码和解码的过程

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)   //中国

执行结果:

go语言基础语法- 字符和字节-字符串_go语言_02

字符串的遍历

(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语言基础语法- 字符和字节-字符串_go语言_03

go语言中的字符串字符不可以修改

package main

import "fmt"

func main() {
	name := "i am 老辛"
	fmt.Println(name[0])
	name[0] = "m"  // 可以看到不允许修改
	}
}


举报

相关推荐

0 条评论