使用range遍历字符串可正确处理UTF-8编码的多字节字符,自动解析为rune。1. range返回字节索引和rune值,能准确输出每个Unicode字符及其位置;2. 可用下划线忽略索引,仅获取字符;3. 频繁操作时建议转为[]rune切片,使索引对应字符位置,便于修改和访问。

在Golang中使用range遍历字符串时,需要注意字符串底层是以字节(byte)形式存储的UTF-8编码。由于Go中的字符串是UTF-8编码的,一个字符可能占用多个字节,直接按字节遍历可能会导致乱码或错误拆分字符。使用range可以正确解码每个Unicode字符。
range遍历字符串时,会自动按UTF-8编码解析每一个Unicode码点(rune)。返回两个值:当前字符的起始字节索引和该字符对应的rune值。
str := "Hello 世界"
for index, char := range str {
fmt.Printf("索引: %d, 字符: %c, Unicode码: %U\n", index, char, char)
}
输出结果:
索引: 0, 字符: H, Unicode码: U+0048 索引: 1, 字符: e, Unicode码: U+0065 索引: 2, 字符: l, Unicode码: U+006C 索引: 3, 字符: l, Unicode码: U+006C 索引: 4, 字符: o, Unicode码: U+006F 索引: 5, 字符: , Unicode码: U+0020 索引: 6, 字符: 世, Unicode码: U+4E16 索引: 9, 字符: 界, Unicode码: U+754C
注意中文“世”从索引6开始,占3个字节,因此下一个字符“界”从索引9开始。
立即学习“go语言免费学习笔记(深入)”;
如果不需要索引,可以用下划线_忽略第一个返回值。
for _, char := range "Go语言" {
fmt.Printf("字符: %c\n", char)
}
</font>
<p>输出:</p>
<font face="Courier New">
<pre class="brush:php;toolbar:false;">
字符: G
字符: o
字符: 语
字符: 言
如果需要多次访问或修改字符,建议先转换成[]rune切片,这样每个元素就是一个rune,索引也对应字符位置而非字节位置。
str := "Hello 世界"
runes := []rune(str)
for i, r := range runes {
fmt.Printf("位置: %d, 字符: %c\n", i, r)
}
输出中“世”的索引是6,“界”是7,与字节索引不同,更适合字符级别的处理。
基本上就这些。用range遍历字符串是最安全的方式,能正确处理多字节字符。若需字符级索引或修改内容,转为[]rune更直观。不复杂但容易忽略编码细节。
以上就是如何在Golang中使用range遍历字符串的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号