Besondere Anwendungsfälle und Tricks für Generika in Go. Verwenden Sie leere Typschnittstellen für die dynamische Typprüfung, um Laufzeittypen zu überprüfen. Verwenden Sie generische Typparameter in Sammlungen, um Container verschiedener Typen zu erstellen. Implementieren Sie generische Methoden, um allgemeine Operationen für verschiedene Parametertypen durchzuführen. Verwenden Sie Typeinschränkungen, um typspezifische Generika zu implementieren und Vorgänge für bestimmte Typen anzupassen.
Besondere Anwendungsfälle und Tipps für Generics in Go
Generics führen neuartige Funktionen ein, die es ermöglichen, flexiblen und effizienten Code zu schreiben. In diesem Artikel werden spezielle Anwendungsfälle und Techniken für Generika in Go untersucht.
1. Verwenden Sie eine leere Typschnittstelle für die dynamische Typprüfung.
any
Typ kann jeden Typ darstellen. Dadurch können wir eine dynamische Typprüfung basierend auf zur Laufzeit ermittelten Typen durchführen.
func isString(v any) bool { _, ok := v.(string) return ok } func main() { x := "hello" y := 10 fmt.Println(isString(x)) // true fmt.Println(isString(y)) // false }
2. Verwendung generischer Typen für Sammlungen
Generische Typparameter können in Sammlungstypen verwendet werden, um einen Container mit verschiedenen Typen zu erstellen.
type Stack[T any] []T func (s *Stack[T]) Push(v T) { *s = append(*s, v) } func (s *Stack[T]) Pop() T { if s.IsEmpty() { panic("stack is empty") } v := (*s)[len(*s)-1] *s = (*s)[:len(*s)-1] return v } func main() { s := new(Stack[int]) s.Push(10) s.Push(20) fmt.Println(s.Pop()) // 20 fmt.Println(s.Pop()) // 10 }
3. Generische Methoden implementieren
Generische Methoden ermöglichen es uns, gemeinsame Operationen für verschiedene Arten von Parametern zu implementieren.
type Num[T numeric] struct { V T } func (n *Num[T]) Add(other *Num[T]) { n.V += other.V } func main() { n1 := Num[int]{V: 10} n2 := Num[int]{V: 20} n1.Add(&n2) fmt.Println(n1.V) // 30 // 可以使用其他数字类型 n3 := Num[float64]{V: 3.14} n4 := Num[float64]{V: 2.71} n3.Add(&n4) fmt.Println(n3.V) // 5.85 }
4. Implementieren Sie typspezifische Generika mithilfe von Typeinschränkungen. Typeinschränkungen schränken den Umfang generischer Typen ein. Es ermöglicht uns, benutzerdefinierte Operationen für bestimmte Typen zu implementieren.
type Comparer[T comparable] interface { CompareTo(T) int } type IntComparer struct { V int } func (c *IntComparer) CompareTo(other IntComparer) int { return c.V - other.V } // IntSlice 实现 Comparer[IntComparer] 接口 type IntSlice []IntComparer func (s IntSlice) Len() int { return len(s) } func (s IntSlice) Less(i, j int) bool { return s[i].CompareTo(s[j]) < 0 } func (s IntSlice) Swap(i, j int) { s[i], s[j] = s[j], s[i] } func main() { s := IntSlice{{10}, {20}, {5}} sort.Sort(s) fmt.Println(s) // [{5} {10} {20}] }
Das obige ist der detaillierte Inhalt vonSpezielle Anwendungsfälle und Techniken von Generika in Golang. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!