Iterieren über eine Zeichenfolge anhand von Runen in Go
In Go kann es vorkommen, dass Sie eine Zeichenfolge anhand ihrer iterieren möchten einzelne Runen oder Unicode-Codepunkte. Sie könnten versucht sein, eine herkömmliche for-Schleife mit dem Index i zu verwenden, um auf jedes Zeichen zuzugreifen:
for i := 0; i < len(str); i++ { dosomethingwithrune(str[i]) // takes a rune }
Dieser Ansatz funktioniert jedoch nicht richtig, da str[i] stattdessen ein Byte (uint8) zurückgibt eine Rune. Um die Zeichenfolge nach Runen zu durchlaufen, müssen Sie die Bereichssyntax verwenden:
for pos, char := range "日本語" { fmt.Printf("character %c starts at byte position %d\n", char, pos) }
Dieser Code gibt die folgende Ausgabe aus:
character 日 starts at byte position 0 character 本 starts at byte position 3 character 語 starts at byte position 6
Wie in der Dokumentation für Effective Go erklärt, Die Bereichssyntax „nimmt Ihnen mehr Arbeit ab, indem sie einzelne Unicode-Codepunkte durch Parsen von UTF-8 herausschlüsselt.“ Dadurch können Sie direkt mit Runen arbeiten, was die Durchführung von Unicode-bezogenen Vorgängen an Ihren Strings erleichtert.
Das obige ist der detaillierte Inhalt vonWie iteriere ich über einen String von Runes in Go?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!