简言
1. go语言的基本数据类型可以直接调用sort()函数进行排序
2. 结构体的排序需要实现三个函数(获取长度函数,交换函数,比较函数)即可
实验如下图
源代码如下
package main
import (
"fmt"
"sort"
)
// 学生信息
type Student struct {
Age int
Score int
}
// 结构体数组
type Students []*Student
// 下面的三个函数必须实现(获取长度函数,交换函数,比较函数(这里比较的是年龄))
func (s Students) Len() int {
return len(s)
}
func (s Students) Swap(i, j int) {
s[i], s[j] = s[j], s[i]
}
func (s Students) Less(i, j int) bool {
return s[i].Age < s[j].Age
}
func main() {
// 新建3个学生信息,这里特意用指针,表示指针也没问题;当然直接用结构体也是可以的
Data := []*Student{}
Data = append(Data, &Student{Age: 10, Score: 100})
Data = append(Data, &Student{Age: 9, Score: 90})
Data = append(Data, &Student{Age: 11, Score: 110})
sort.Sort(sort.Reverse(Students(Data)))
fmt.Printf("根据年龄从大到小排序 \n")
for i := 0; i < len(Data); i++ {
fmt.Printf("第%v个学生%+v \n", i, Data[i])
}
sort.Sort(Students(Data))
fmt.Printf("\n根据年龄从小到大排序 \n")
for i := 0; i < len(Data); i++ {
fmt.Printf("第%v个学生%+v \n", i, Data[i])
}
}