接口-sort自定义排序
# go 语言 sort.interface{}排序模式
Go 语言中的 sort 包提供了对切片排序的函数和方法,但是需要开发者自己提供排序的方法。因为在不同的场景下,可能需要根据不同的字段来排序,比如按照整数大小、字符串长度、时间先后顺序等等;同时也可能需要自定义比较函数的规则,例如升序还是降序。 在 sort 包中,开发者需要实现一个 Less 方法来定义排序的规则。这个方法接受两个参数,即要比较的两个元素,返回一个 bool 类型的值表明哪个元素应该排在前面。例如:
package main
import (
"fmt"
"sort"
)
type Person struct {
Name string
Age int
}
type ByAge []Person
func (a ByAge) Len() int { return len(a) }
func (a ByAge) Swap(i, j int) { a[i], a[j] = a[j], a[i] }
func (a ByAge) Less(i, j int) bool { return a[i].Age > a[j].Age }
func main() {
people := []Person{
{"Alice", 25},
{"Bob", 30},
{"Carol", 20},
{"David", 35},
}
sort.Sort(ByAge(people))
fmt.Println(people)
}