遍歷字符串有下面兩種寫法。
遍歷每一個ASCII字符
遍歷 ASCII 字符使用 for 的數值循環進行遍歷,直接取每個字符串的下標獲取 ASCII 字符,如下面的例子所示。
theme := "狙擊 start" for i := 0; i < len(theme); i++ { fmt.Printf("ascii: %c %d\n", theme[i], theme[i]) }
程序輸出如下:
ascii: ? 231 ascii: 139 ascii: 153 ascii: ? 229 ascii: 135 ascii: ? 187 ascii: 32 ascii: s 115 ascii: t 116 ascii: a 97 ascii: r 114 ascii: t 116
這種模式下取到的漢字“慘不忍睹”。由於沒有使用 Unicode,漢字被顯示為亂碼。
按Unicode字符遍歷字符串
同樣的內容:
theme := "狙擊 start" for _, s := range theme { fmt.Printf("Unicode: %c %d\n", s, s) }
程序輸出如下:
Unicode: 狙 29401 Unicode: 擊 20987 Unicode: 32 Unicode: s 115 Unicode: t 116 Unicode: a 97 Unicode: r 114 Unicode: t 116
可以看到,這次漢字可以正常輸出了。
總結
- ASCII 字符串遍歷直接使用下標。
- Unicode 字符串遍歷用 for range。