golang中按照结构体的某个字段排序实例代码

目录

  • 概述
  • 从大到小排序
  • 按照结构体的某个字段排序
  • 使用 sort.Stable 进行稳定排序
  • 附:根据结构体中任意字段进行排序
  • 总结

概述 golang的sort包默认支持int, float64, string的从小大到排序:
int -> Ints(x []int)
float64 -> Float64s(x []float64)
string -> Strings(x []string)
同时它还提供了自定义的排序接口Interface,此接口保护三个方法。
type Interface interface {// Len is the number of elements in the collection.Len() int// Less reports whether the element with// index i should sort before the element with index j.Less(i, j int) bool// Swap swaps the elements with indexes i and j.Swap(i, j int)}

golang默认提供了三个类型,他们都实现了Interface:
Float64Slice
IntSlice
StringSlice

从大到小排序 方法1:先使用提供的从大到小排序,再翻转
arr := []float64{0.1, 0.5, 0.8, 0.4, 0.2}sort.Sort(sort.Reverse(sort.Float64Slice(arr)))fmt.Println(arr) // [0.8 0.5 0.4 0.2 0.1]

方法二:自定义类型实现
type Float64SliceDecrement []float64func (s Float64SliceDecrement) Len() int { return len(s) }func (s Float64SliceDecrement) Swap(i, j int) { s[i], s[j] = s[j], s[i] }func (s Float64SliceDecrement) Less(i, j int) bool { return s[i] > s[j] }func main() { arr := []float64{0.1, 0.5, 0.8, 0.4, 0.2} sort.Sort(Float64SliceDecrement(arr)) fmt.Println(arr) // [0.8 0.5 0.4 0.2 0.1]}


按照结构体的某个字段排序 按年纪从大到小排序
type Persons struct { Age int Height int}type PersonsSliceDecrement []Personsfunc (s PersonsSliceDecrement) Len() int { return len(s) }func (s PersonsSliceDecrement) Swap(i, j int) { s[i], s[j] = s[j], s[i] }func (s PersonsSliceDecrement) Less(i, j int) bool { return s[i].Age > s[j].Age }func main() { arr1 := []Persons{Persons{10, 12},Persons{20, 12},Persons{9, 12},Persons{10, 12},Persons{11, 12}, } sort.Sort(PersonsSliceDecrement(arr1)) fmt.Println(arr1)}

打印
[{20 12} {11 12} {10 12} {10 12} {9 12}]
按年纪从大到小,如果年纪相等的,按身高从小到到
type Persons struct { Age int Height int}type PersonsSliceDecrement []Personsfunc (s PersonsSliceDecrement) Len() int { return len(s) }func (s PersonsSliceDecrement) Swap(i, j int) { s[i], s[j] = s[j], s[i] }func (s PersonsSliceDecrement) Less(i, j int) bool { if s[i].Age > s[j].Age {return true } if s[i].Age == s[j].Age && s[i].Height < s[j].Height {return true } return false}func main() { arr1 := []Persons{Persons{10, 120},Persons{20, 12},Persons{10, 110},Persons{10, 11},Persons{10, 100}, } sort.Sort(PersonsSliceDecrement(arr1)) fmt.Println(arr1)}

打印
[{20 12} {10 11} {10 100} {10 110} {10 120}]

使用 sort.Stable 进行稳定排序 sort.Sort 并不保证排序的稳定性。如果有需要, 可以使用 sort.Stable ,用法就是将sort.Sort 替换为 sort.Stable
附:go根据结构体中任意字段进行排序

附:根据结构体中任意字段进行排序 Sort()
Reverse()
Less(i,j int) bool
Len() int
Swap(i,j int)
package mainimport ( "fmt" "sort")type Student struct { Numberstring Namestring Ageint IsWalker bool Weightfloat32}type ByNumber []*Studentfunc (this ByNumber)Len() int{ return len(this)}func (this ByNumber)Less(i,j int) bool{ return this[i].Numberj.Number}if i.Name!=j.Name{return i.Name

总结 【golang中按照结构体的某个字段排序实例代码】到此这篇关于golang中按照结构体的某个字段排序的文章就介绍到这了,更多相关golang按字段排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    推荐阅读