go中的rune类型

go语言中 ,rune其实是一种int32的数据类型的别名。

Go 复制代码
// rune is an alias for int32 and is equivalent to int32 in all ways. It is
// used, by convention, to distinguish character values from integer values.
type rune = int32

rune通常用于处理字符串中的单个字符,通常来区分整数值和字符值。

看下面的例子:

Go 复制代码
// 单元测试
func TestRune1(t *testing.T) {
	fmt.Println("The Shy:", len("The Shy"))
	fmt.Println("英雄联盟:", len("英雄联盟"))
}

结果:
=== RUN   TestRune1
The Shy: 7
英雄联盟: 12
--- PASS: TestRune1 (0.00s)
PASS

看上面的结果The Shy: 7,这个好理解,英文的字符串的长度为7,英雄联盟: 12。为什么英雄联盟这个长度是12呢?

这是因为go语言的编码是按照UTF-8编码规则来的。UTF-8是一套以 8 位为一个编码单位的可变长编码。汉字的16进制值得区间在UTF-8的第三区段,那么在go的编码下会占用三个字符。所以在我们对字符串进去处理的时候只需要将字符串通过range去遍历,会按照rune为单位自动去处理。

Go 复制代码
func TestRune1(t *testing.T) {
	fmt.Println("The Shy:", len("The Shy"))
	fmt.Println("英雄联盟:", len("英雄联盟"))

	fmt.Println("-------------------")

	s := "英雄联盟"
	for k, v := range s {
		fmt.Printf("k:%v->v:%v->realValue:%c,", k, v, v)
		fmt.Println()
	}
	fmt.Println(len(s))
}

// 结果:
=== RUN   TestRune1
The Shy: 7
英雄联盟: 12
-------------------
k:0->v:33521->realValue:英,
k:3->v:38596->realValue:雄,
k:6->v:32852->realValue:联,
k:9->v:30431->realValue:盟,
12
--- PASS: TestRune1 (0.00s)
PASS

可以看到,rune已经将字符串中每个字符转换为Unicode码点。

结果打印:打印出字符在字符串中的索引位置 k 和对应的Unicode码点 v 。

那码点怎么转化为汉字呢?

在Go语言中,可以使用 %c

复制代码
fmt.Printf("k:%v->v:%v->realValue:%c,", k, v, v)

将Unicode码点转换为对应的字符(汉字)。其中,%c 是一个占位符,表示将一个Unicode码点格式化为对应的字符。

小结:

rune其实就是int32的数据类型,对于汉字等,将汉字转化为Unicode码点。

可以通过%c来获取码点对应的值。

相关推荐
serendipity_hky4 小时前
【go语言 | 第2篇】Go变量声明 + 常用数据类型的使用
开发语言·后端·golang
周杰伦_Jay6 小时前
【Eino框架】Go语言驱动的LLM应用开发新范式
开发语言·后端·golang
2501_941982058 小时前
Go 进阶:发送文件/图片消息的流程与实现
开发语言·后端·golang
2501_944875518 小时前
Go后端工程师
开发语言·后端·golang
理人综艺好会9 小时前
Redis学习之go-redis
redis·学习·golang
bing.shao9 小时前
Golang WaitGroup 踩坑
开发语言·数据库·golang
周杰伦_Jay10 小时前
【Go/Python/Java】基础语法+核心特性对比
java·python·golang
serendipity_hky11 小时前
【go语言 | 第3篇】go中类的封装、继承、多态 + 反射
开发语言·后端·golang·反射
Kiri霧13 小时前
Go切片详解
开发语言·后端·golang
古城小栈13 小时前
Go 与 Rust:系统编程语言的竞争与融合
开发语言·golang·rust