解释Golang的rune类型和byte类型有什么不同

rune是字符,byte是字节。Go中byte为uint8别名,用于处理ASCII和二进制数据;rune为int32别名,表示Unicode码点,用于正确处理中文、emoji等多字节字符。字符串以UTF-8存储,一个字符可能占多个字节。如”你好”占6字节但仅2字符。用len(str)得字节数,len([]rune(str))得字符数。文件操作用byte,文本处理用rune。

解释golang的rune类型和byte类型有什么不同

在Go语言中,runebyte都是用于表示数据的基本类型,但它们的用途和底层含义有明显区别,主要体现在对字符和字符串的处理方式上。

byte 类型:表示一个字节

byte 是 uint8 的别名,表示一个 8 位无符号整数,取值范围是 0 到 255。它通常用来处理原始的二进制数据或 ASCII 字符。

在字符串中,byte 对应的是字符串的每一个字节。由于 Go 中的字符串是以 UTF-8 编码存储的,一个字符可能占用多个字节,尤其是非 ASCII 字符(如中文、emoji)。

示例:

立即学习“go语言免费学习笔记(深入)”;

字符串 “hello” 有 5 个字符,每个字符是 ASCII,所以可以用 5 个 byte 表示。
字符串 “你好” 是 UTF-8 编码,每个汉字占 3 个字节,总共 6 个字节,但只有 2 个字符。

rune 类型:表示一个 Unicode 码点

rune 是 int32 的别名,表示一个 Unicode 码点(code point),即一个完整的字符。它能正确处理包括中文、日文、emoji 等在内的所有 Unicode 字符。

当你需要遍历字符串中的“字符”而不是“字节”时,应该使用 rune。使用 range 遍历字符串时,Go 会自动将 UTF-8 编码的字节序列解码为 rune。

常见操作对比:

用 []byte(str) 可以把字符串转为字节切片,按字节访问 用 []rune(str) 可以把字符串转为 rune 切片,按字符访问

例子:

str := “你好, world!”
len(str) → 返回 13(字节数)
len([]rune(str)) → 返回 9(字符数)

使用建议

当你处理的是:

文件读写、网络传输、二进制协议 → 用 byte 文本处理、字符串遍历、国际化字符 → 用 rune

基本上就这些。简单说:byte 是字节,rune 是字符,特别是在 UTF-8 环境下,区分它们很重要。

以上就是解释Golang的rune类型和byte类型有什么不同的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1402851.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月15日 19:03:42
下一篇 2025年12月15日 19:03:59

相关推荐

发表回复

登录后才能评论
关注微信