for range 遍历字符串时按 rune 拆分中文不会乱码「北京」被正确识别为两个 rune索引与值一一对应避免了按字节遍历导致的乱码问题。用 for range 遍历字符串中文不会乱码Go 的 for range 遍历字符串时自动按 runeUnicode 码点拆分不是按字节。这意味着「北京」两个汉字会被正确识别为两个独立字符索引和值一一对应。常见错误现象有人写 for i : 0; i 然后取 codestr[i]遇到中文就输出乱码或截断——因为 len() 返回的是字节数而一个中文占 3 字节str[6] 可能只是「北」的第二个字节。range 返回的 index 是该字符在字符串中的起始字节位置不是第几个字符比如 你好 中「好」的 index 是 3val 类型是 rune即 int32不是 byte所以 fmt.Printf(%c, val) 能正常打印中文不需要手动转 []runerange 已内置 UTF-8 解码逻辑什么时候必须转成 []rune只有当你需要「按字符序号索引」或「修改/重排字符顺序」时才需要显式转切片。因为字符串本身不可变且原生不支持下标取「第 N 个字符」。使用场景举例提取第 3 个汉字、反转字符串、去重相邻字符等。立即学习“go语言免费学习笔记深入” Tellers AI Tellers是一款自动视频编辑工具可以将文本、文章或故事转换为视频。