rune用于处理Unicode字符,byte用于ASCII或字节操作;中文等多字节字符用rune才能准确计数和遍历。

在Go语言中,rune 和 byte 是两个常用于处理字符和字符串的类型,但它们的用途和底层表示有明显区别。理解它们的不同,对正确处理文本(尤其是中文等多字节字符)非常重要。
byte 实际上是 uint8 的别名,用来表示 8 位无符号整数,取值范围是 0 到 255。它通常用于处理 ASCII 字符或原始字节数据。
例如,英文字符 'A' 的 ASCII 码是 65,可以用 byte 表示:
[]byte(str)
rune 是 int32 的别名,用来表示一个 Unicode 字符(即一个码点)。它可以正确表示包括中文、emoji 等在内的任何 Unicode 字符。
立即学习“go语言免费学习笔记(深入)”;
例如,汉字“你”的 Unicode 码点是 U+4F60,需要用 rune 才能准确表示。
[]rune(str)
看一个例子更容易理解:
str := "你好, world!" fmt.Println(len(str)) // 输出: 13 (字节数) fmt.Println(len([]rune(str))) // 输出: 9 (字符数,包含中文)
len(str)
[]rune(str)
基本上就这些。简单说:处理 ASCII 或二进制数据用 byte,处理国际化文本、中文、emoji 用 rune,避免乱码和长度误判。
以上就是Golangrune和byte的区别在哪的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号