Heim >Backend-Entwicklung >Golang >Wie prüft Go die Elementmitgliedschaft ohne ein „if x in'-Konstrukt?
Gos Ansatz für das „if x in“-Konstrukt
Go bietet verschiedene Ansätze zum Überprüfen, ob ein Element in einem Array vorhanden ist, oder zum Überprüfen der Mitgliedschaft. Obwohl es kein explizites „if x in“-Konstrukt wie Python hat, bietet es je nach Version und verwendeter Datenstruktur einige Alternativen.
1. Verwendung von Slices.Contains (Go 1.18 und höher)
Für Go 1.18 und spätere Versionen bietet die Slices.Contains-Methode eine direkte und effiziente Lösung. Es nimmt ein Array oder Slice als Eingabe und prüft, ob das angegebene Element vorhanden ist.
arr := []string{"a", "b", "c"} if slices.Contains(arr, "b") { // Element is present }
2. Iterieren über das Array (vor Go 1.18)
Vor Go 1.18 gab es keinen integrierten Operator zum Überprüfen der Mitgliedschaft. Stattdessen könnte eine benutzerdefinierte Funktion erstellt werden, um das Array zu durchlaufen:
func stringInSlice(a string, list []string) bool { for _, b := range list { if b == a { return true } } return false }
3. Verwendung einer Karte für Mitgliedschaftsprüfungen
Wenn die Iteration über die gesamte Liste unerwünscht ist, kann die Verwendung einer Karte anstelle eines Arrays oder Slice eine effizientere Lösung für Mitgliedschaftsprüfungen darstellen:
visitedURL := map[string]bool { "http://www.google.com": true, "https://paypal.com": true, } if visitedURL[thisSite] { fmt.Println("Already been here.") }
Das obige ist der detaillierte Inhalt vonWie prüft Go die Elementmitgliedschaft ohne ein „if x in'-Konstrukt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!