Sortieren eines Strukturarrays nach Time.Time-Mitglied in Go
In Go kann das Sortieren einer Datenstruktur nach einem bestimmten Mitglied mit erfolgen Paketsortierung. Dies ist in verschiedenen Szenarios nützlich, beispielsweise wenn Sie Elemente chronologisch basierend auf einem Datums- oder Zeitfeld ordnen möchten.
Um einen Teil von Strukturen basierend auf einem time.Time-Mitglied zu sortieren, können Sie einen benutzerdefinierten Typ definieren das die Schnittstelle sort.Interface implementiert. Dieser Typ muss die folgenden Methoden definieren:
Im angegebenen Code haben Sie einen Typ timeSlice definiert, der diese Methoden implementiert. Allerdings vergleicht die Less-Methode die Zeiger mit den time.Time-Werten und nicht mit den tatsächlichen Werten. Um dies zu beheben, können Sie die Before-Methode von time.Time verwenden, um die Zeitwerte direkt zu vergleichen:
func (p timeSlice) Less(i, j int) bool { return p[i].date.Before(p[j].date) }
Sobald Sie den benutzerdefinierten Typ definiert haben, können Sie das Slice mit der Funktion sort.Sort sortieren. Für Go-Versionen 1.8 und höher können Sie jedoch die Funktion sort.Slice verwenden, die effizienter und prägnanter ist:
sort.Slice(timeSlice, func(i, j int) bool { return timeSlice[i].date.Before(timeSlice[j].date) })
Die Funktion sort.Slice benötigt zwei Argumente: das zu sortierende Slice und ein Abschluss, der die Vergleichsfunktion definiert. In diesem Fall gibt der Abschluss true zurück, wenn das Element am Index i kleiner als das Element am Index j ist, andernfalls false.
Nach dem Sortieren des Slice werden die Elemente basierend auf dem Datum in aufsteigender Reihenfolge angeordnet Mitglied.
Das obige ist der detaillierte Inhalt vonWie sortiere ich ein Segment von Strukturen effizient nach einem „time.Time'-Mitglied in Go?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!