Golang ist nicht dabei

WBOY
Freigeben: 2023-05-16 09:27:07
Original
401 Leute haben es durchsucht

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')
Nach dem Login kopieren

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}
Nach dem Login kopieren
Nach dem Login kopieren

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])
Nach dem Login kopieren

Das Ausgabeergebnis lautet:

3
Nach dem Login kopieren

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,
}
Nach dem Login kopieren

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"])
Nach dem Login kopieren

Die Ausgabe lautet:

34
Nach dem Login kopieren

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:

  1. Verwenden einer for-Schleife

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}
Nach dem Login kopieren
Nach dem Login kopieren

, können Sie den folgenden Code verwenden:

for _, number := range numbers {
    if number == 3 {
        fmt.Println("3 is in numbers")
        break
    }
}
Nach dem Login kopieren

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
    }
}
Nach dem Login kopieren

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.

  1. Verwenden Sie Sortierung und binäre Suche.

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")
}
Nach dem Login kopieren

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")
}
Nach dem Login kopieren

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.

  1. Verwenden Sie den Nullwert von Map

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"])
}
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!