package main
import (
"fmt"
"sort"
)
type byLength []string
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])
}
func main() {
strs := []string{"c", "b", "a"}
ints := []int{3, 2, 1}
sort.Strings(strs)
sort.Ints(ints)
isSorting := sort.IntsAreSorted(ints)
fmt.Println(strs, ints, isSorting)
fruits := []string{"peach", "banana", "kiwi"}
sort.Sort(byLength(fruits))
fmt.Println(fruits)
// 对切片数据排序
// 数据源省略。。。
sort.Slice(params, func(i, j int) bool {
return params[i].Name < params[j].Name
})
}
go-基础-排序
于 2022-01-06 09:30:22 首次发布