Golang ist eine sehr beliebte Open-Source-Programmiersprache. Sie kann in verschiedenen Szenarien verwendet werden, sei es bei der Webentwicklung oder bei Back-End-Diensten, und verfügt über ein breites Anwendungsspektrum. Allerdings gibt es in Golang keinen in-Operator, der in Sprachen wie Python oder SQL üblich ist. Welche Auswirkungen wird es auf unsere Programmierung haben, da es keinen In-Operator gibt? In diesem Artikel wird dieses Thema untersucht und alternative Möglichkeiten zur Implementierung des in-Operators vorgestellt.
Was ist drin?
in ist ein universeller Operator, der in vielen Programmiersprachen verwendet werden kann. Es wird häufig verwendet, um festzustellen, ob ein Wert in einer Sammlung oder einem Array vorhanden ist. In Python können Sie beispielsweise in verwenden, um zu überprüfen, ob eine Zahl in einer Liste enthalten ist:
if x in [1, 2, 3]: print('x is in the list')
Wenn im obigen Code der Wert von x einer von 1, 2 oder 3 ist, wird „x ist in“ ausgegeben Liste".
Golangs Slice und Map
In Golang ist Slice ein dynamisches Array, das automatisch erweitert oder verkleinert werden kann. Auf Slice-Elemente kann über Indizes zugegriffen werden (beginnend bei 0). Hier ist zum Beispiel ein Beispiel für einen Slice:
numbers := []int{1, 2, 3, 4, 5}
Im obigen Code ist „numbers“ ein Slice mit 5 ganzen Zahlen. Um auf das dritte Element zuzugreifen, können Sie den folgenden Code verwenden:
fmt.Println(numbers[2])
Das Ausgabeergebnis lautet:
3
In ähnlicher Weise ist Map in Golang auch eine sehr häufige Datenstruktur, die Schlüssel und Werte einzeln zuordnet und sein kann Zugriff über Schlüsselwert. Hier ist zum Beispiel ein Beispiel für eine Karte:
ages := map[string]int{ "Alice": 31, "Bob": 34, "Cindy": 27, }
Wie im Code oben gezeigt, ist ages eine Karte, die Zeichenfolgen ganzen Zahlen zuordnet. Um beispielsweise Bobs Alter zu ermitteln, können Sie den folgenden Code verwenden:
fmt.Println(ages["Bob"])
Die Ausgabe lautet:
34
Die oben genannten sind häufig verwendete Sammlungstypen in Golang. Obwohl diese Typen in vielen Situationen nützlich sind, kann das Fehlen des in-Operators dennoch zu Unannehmlichkeiten bei der Programmierung führen.
Alternativen
Obwohl es keinen In-Operator gibt, bietet Golang dennoch mehrere Methoden zur Durchführung ähnlicher Vorgänge. Hier sind einige davon:
Die einfachste Möglichkeit besteht darin, eine for-Schleife zu verwenden, um die Sammlung zu durchlaufen und das gesuchte Element zu finden. Um beispielsweise zu überprüfen, ob die Zahl 3 in der folgenden Liste enthalten ist:
numbers := []int{1, 2, 3, 4, 5}
, können Sie den folgenden Code verwenden:
for _, number := range numbers { if number == 3 { fmt.Println("3 is in numbers") break } }
Beachten Sie, dass hier das Schlüsselwort „range“ und der Bezeichner _blank verwendet werden, um alle Elemente im Slice zu durchlaufen.
Ähnlich können Sie den folgenden Code verwenden, um zu überprüfen, ob ein Schlüssel in der Karte vorhanden ist:
ages := map[string]int{ "Alice": 31, "Bob": 34, "Cindy": 27, } for name, age := range ages { if name == "Bob" { fmt.Printf("Bob's age is %d ", age) break } }
Dieser Code durchläuft alle Schlüssel-Wert-Paare des Alters und findet heraus, ob der Schlüssel gleich „Bob“ ist.
Die Verwendung einer for-Schleife ist eine einfache Möglichkeit, so etwas wie den in-Operator zu implementieren. Bei der Suche nach Elementen in einer großen Sammlung ist sie jedoch möglicherweise nicht effizient genug.
Wenn die Elemente in der Menge geordnet sind, können Sie Sortier- und binäre Suchalgorithmen verwenden, um die Elemente zu finden. Hier ist ein Beispiel:
numbers := []int{1, 2, 3, 4, 5} sort.Ints(numbers) if i := sort.SearchInts(numbers, 3); i < len(numbers) && numbers[i] == 3 { fmt.Println("3 is in numbers") }
Dieser Code verwendet sort.Ints, um ein Array zu sortieren, und verwendet dann sort.SearchInts, um eine binäre Suche durchzuführen, um herauszufinden, ob 3 im Array vorhanden ist.
Ebenso ist es auch möglich, die Schlüssel der Karte zu sortieren und eine binäre Suche mit sort.SearchStrings durchzuführen. Zum Beispiel:
names := []string{"Alice", "Bob", "Cindy"} sort.Strings(names) if i := sort.SearchStrings(names, "Bob"); i < len(names) && names[i] == "Bob" { fmt.Println("Bob is in names") }
Dieser Code verwendet sort.Strings, um ein Array von Zeichenfolgen zu sortieren, und verwendet dann sort.SearchStrings, um eine binäre Suche durchzuführen, um herauszufinden, ob „Bob“ im Array enthalten ist.
Beachten Sie, dass die Verwendung von Sortierung und binärer Suche nur anwendbar ist, wenn die Elemente sortiert wurden. Wenn die eingestellten Elemente zufällig verteilt sind, kann die Effizienz sehr gering sein.
Wenn Sie nur überprüfen müssen, ob ein Schlüssel in der Karte vorhanden ist, können Sie den Nullwert von Map verwenden. Der Nullwert gibt einen Nullwert für diesen Typ zurück, wenn der angegebene Schlüssel nicht in der Karte vorhanden ist. Zum Beispiel:
ages := map[string]int{ "Alice": 31, "Bob": 34, "Cindy": 27, } if ages["Bob"] != 0 { fmt.Printf("Bob's age is %d ", ages["Bob"]) }
Dieser Code prüft, ob der Schlüssel „Bob“ in der Karte vorhanden ist, und gibt in diesem Fall Bobs Alter aus.
Diese Methode kann jedoch einige Probleme verursachen. Denn wenn der dem Schlüssel entsprechende Wert ursprünglich Null ist, glaubt das Programm möglicherweise fälschlicherweise, dass der Schlüssel nicht existiert. Daher funktioniert diese Methode nur, wenn der Wert in der Karte nicht Null ist.
Fazit
Obwohl Golang keinen integrierten Operator hat, können wir eine ähnliche Funktionalität erreichen, indem wir For-Schleifen, Sortierung und binäre Suche sowie den Nullwert von Map verwenden. Abhängig vom jeweiligen Szenario kann die Auswahl der geeigneten Methode den Code effizienter, lesbarer und wartbarer machen.
Das Obige ist der in diesem Artikel vorgestellte Inhalt. Ich hoffe, dass die Leser das Problem des Mangels an Operatoren in Golang besser verstehen können.
Das obige ist der detaillierte Inhalt vonGolang ist nicht dabei. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!