Heim > Artikel > Backend-Entwicklung > Wie kann ich einen generischen Vergleichsoperator in Go implementieren?
Wie heißt die vergleichbare Schnittstelle?
In Go gibt es keine vordefinierte Schnittstelle, die einen generischen Vergleichsoperator (<) bereitstellt. Stattdessen können Sie Ihre eigene Less-Funktion definieren, um Ihre Typen zu vergleichen. Die Less-Funktion akzeptiert zwei Argumente desselben Typs und gibt einen booleschen Wert zurück, der angibt, ob das erste Argument kleiner als das zweite ist.
Hier ist ein Beispiel einer Less-Funktion, die ganze Zahlen und Zeichenfolgen vergleichen kann:
func Less(a, b interface{}) bool { switch a.(type) { case int: if ai, ok := a.(int); ok { if bi, ok := b.(int); ok { return ai < bi } } case string: if ai, ok := a.(string); ok { if bi, ok := b.(string); ok { return ai < bi } } // ... default: panic("Unknown") } return false }
Sie können die Funktion „Weniger“ verwenden, um Elemente in eine sortierte verknüpfte Liste einzufügen:
func Insert(val interface{}, l *list.List) *list.Element { e := l.Front() if e == nil { return l.PushFront(val) } for ; e != nil; e = e.Next() { if Less(val, e.Value) { return l.InsertBefore(val, e) } } return l.PushBack(val) }
Diese Funktion „Einfügen“ behält die verknüpfte Liste bei in sortierter Reihenfolge basierend auf der Less-Funktion.
Das obige ist der detaillierte Inhalt vonWie kann ich einen generischen Vergleichsoperator in Go implementieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!