sort パッケージの Sort 関数を使えるように、
sort.Interface すなわち Len , Less , Swap
関数を実装します。
Len と Swap はどの型でもだいたい同じになり、
Less が実際のカスタムソートのロジックをもちます。
この例では、文字列の長さの昇順でソートしたいので、
len(s[i]) と len(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])
}
|
元の fruits スライスを byLength に型変換し、
sort.Sort 関数を使うことでカスタムソートを実現できます。
|
func main() {
fruits := []string{"peach", "banana", "kiwi"}
sort.Sort(byLength(fruits))
fmt.Println(fruits)
}
|