golang sort包

golang sort包可以对所有实现了sort.interface的接口对象slice排序,排序时候使用的是插入排序,快速排序还是桶排序是包自身选择的,当你做的排序并没有极高的性能要求时,可以直接使用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 }

people := []Person{
        {"Bob", 31},
        {"John", 42},
        {"Michael", 17},
        {"Jenny", 26},
    }
sort.Sort(ByAge(people)

字符串的排序很常用,比如搜索结果按首字母排序等等,所以直接实现了string Slice的排序
sort.Strings()
当然也可以反向排序
可以看看Reverse,使用上直接sort.Sort(sort.Reverse(ByAge(people)))
即可,内部实现上是通过组合使用原有interface并重新定义less方法实现的
这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值