|
Implementujeme interface sort.Interface - Len, Less, a
Swap - na našem typu, takže můžeme použít generickou funkci
Sort z balíčku sort.LenaSwapbudou
obvykle podobné napříč typy aLessbude obsahovat
vlastní třídící logiku. V našem případě chceme třídit podle
délky řetězce vzestupně, takže zde použijeme
len(s[i])alen(s[j])`.
|
func (s byLength) Len() int {
return len(s)
}
func (s byLength) Swap(i, j int) {
s[i], s[j] = s[j], s[i]
}
func (s byLength) Less(i, j int) bool {
return len(s[i]) < len(s[j])
}
|
|
Když máme všechno připravené, nyní můžeme naimplementovat
naše volitelné třídění překonvertováním původního výřezu fruits
na byLength a poté na výřez s tímto typem použít sort.Sort.
|
func main() {
fruits := []string{"peach", "banana", "kiwi"}
sort.Sort(byLength(fruits))
fmt.Println(fruits)
}
|