Elegante Array-Sortierung in Go
Beim Umgang mit Arrays von Strukturen wird die Sortierung entscheidend. In Go können wir die in Go 1.8 eingeführte Funktion sort.Slice nutzen, um dies mühelos zu erreichen.
Beispiel:
Betrachten Sie ein Array von Planet-Strukturen:
type Planet struct { Name string Aphelion float64 Perihelion float64 Axis int64 Radius float64 }
Sortieren nach Achse:
Um dieses Array nach dem Achsenfeld zu sortieren, können wir den folgenden Code verwenden:
sort.Slice(planets, func(i, j int) bool { return planets[i].Axis < planets[j].Axis })
Diese Funktion verwendet ein Slice als erstes Argument und eine Vergleichsfunktion als das zweite Argument. Die Vergleichsfunktion bestimmt, wie die Elemente sortiert werden sollen. In diesem Fall gibt die Vergleichsfunktion „true“ zurück, wenn der Achsenwert am Index i kleiner als der Achsenwert am Index j ist, was darauf hinweist, dass das Element bei i vor dem Element bei j sortiert werden sollte.
Vorsichtsmaßnahme bei Arrays:
Wenn wir mit Arrays arbeiten, müssen wir diese in Slices konvertieren, bevor wir sort.Slice verwenden. Dies liegt daran, dass Arrays eine feste Größe haben und im Gegensatz zu Slices nicht dynamisch in der Größe geändert werden können.
sort.Slice(planets[:], func(i, j int) bool { return planets[i].Axis < planets[j].Axis })
Durch Hinzufügen der [:]-Syntax zum Slice erstellen wir effektiv ein Slice, das das Array überlagert. Dadurch können wir das Array über das Slice hinweg modifizieren.
Dieser elegante und unkomplizierte Ansatz vereinfacht die Array-Sortierung in Go und macht sie so einfach wie sein Python-Gegenstück, wo sorted(planets, key=lambda n: n.Axis ) erzielt das gleiche Ergebnis.
Das obige ist der detaillierte Inhalt vonWie kann ich Arrays von Strukturen in Go effizient sortieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!