Iterieren über Strings durch Runen in Go
Beim Iterieren über Strings in Go stoßen Entwickler häufig auf die Notwendigkeit, mit Runen (Unicode-Code) zu arbeiten Punkte) anstelle von Bytes. Dies liegt daran, dass der String-Typ von Go Bytes und keine Runen speichert.
Betrachten Sie das folgende Code-Snippet:
for i := 0; i < len(str); i++ { dosomethingwithrune(str[i]) // takes a rune }
Dieses Snippet soll die Zeichen in der Zeichenfolge str durchlaufen und dabei eine Aktion ausführen mit jeder Rune. Der Zugriff auf str[i] gibt jedoch ein Byte und keine Rune zurück.
Um über die Runen in einer Zeichenfolge zu iterieren, stellt Go speziell für diesen Zweck einen Bereichsausdruck bereit:
for pos, char := range "日本語" { fmt.Printf("character %c starts at byte position %d\n", char, pos) }
In Im obigen Beispiel durchläuft der Bereichsausdruck die Runen in der Zeichenfolge und weist die aktuelle Rune der Variablen char und die aktuelle Byteposition der Variablen pos zu.
Der Vorteil des Bereichsausdrucks besteht darin, dass er UTF verarbeitet -8 automatische Dekodierung, Aufschlüsselung einzelner Unicode-Codepunkte. Dies vereinfacht die Aufgabe der Iteration über die Runen in einer Zeichenfolge und vermeidet gleichzeitig die potenziellen Fallstricke einer manuellen Iteration.
Das obige ist der detaillierte Inhalt vonWie iteriere ich über Runen in einem Go-String?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!