遍历字符串有下面两种写法。
遍历每一个ASCII字符
遍历 ASCII 字符使用 for 的数值循环进行遍历,直接取每个字符串的下标获取 ASCII 字符,如下面的例子所示。
package main
import "fmt"
func main(){
theme := "狙击 start"
for i := 0; i < len(theme); i++ {
fmt.Printf("ascii: %c %d\n", theme[i], theme[i])
}
}

这种模式下取到的汉字“惨不忍睹”。由于没有使用 Unicode,汉字被显示为乱码。
按Unicode字符遍历字符串
package main
import "fmt"
func main(){
theme := "狙击 start"
for _, s := range theme {
fmt.Printf("Unicode: %c %d\n", s, s)
}
}

可以看到,这次汉字可以正常输出了。
总结
- ASCII 字符串遍历直接使用下标。
- Unicode 字符串遍历用 for range。
本文探讨了在Go语言中遍历字符串的两种方式:使用for循环遍历ASCII字符和使用for range遍历Unicode字符。通过示例代码展示了ASCII遍历可能出现的汉字乱码问题,以及Unicode遍历如何正确输出汉字。了解这两种遍历方式对于理解和处理多语言字符串至关重要。

被折叠的 条评论
为什么被折叠?



