golang 排序切片升序或降序

新手上路,请多包涵

我需要对来自 3rdparty 包的类型的一部分进行排序。根据某些条件,顺序必须是升序或降序。

我想出的解决方案是:

 type fooAscending []foo

func (v fooAscending) Len() int           { return len(v) }
func (v fooAscending) Swap(i, j int)      { v[i], v[j] = v[j], v[i] }
func (v fooAscending) Less(i, j int) bool { return v[i].Amount < v[j].Amount }

type fooDescending []foo

func (v fooDescending) Len() int           { return len(v) }
func (v fooDescending) Swap(i, j int)      { v[i], v[j] = v[j], v[i] }
func (v fooDescending) Less(i, j int) bool { return v[i].Amount > v[j].Amount }

if someCondition {
    sort.Sort(fooAscending(array))
} else {
    sort.Sort(fooDescending(array))
}

有一个更好的方法吗。这个任务有 13 行代码,其中大部分是重复的,似乎有点太多了。

原文由 gsf 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 913
2 个回答

从 Go 1.8 开始,有一种更简单的方法可以对切片进行排序,不需要您定义新类型。您只需将匿名函数传递给 sort.Slice 函数。

 a := []int{5, 3, 4, 7, 8, 9}
sort.Slice(a, func(i, j int) bool {
    return a[i] < a[j]
})
for _, v := range a {
    fmt.Println(v)
}

这将按升序排序,如果您想要相反的顺序,只需在匿名函数中写入 a[i] > a[j] 即可。

原文由 Franck Jeannin 发布,翻译遵循 CC BY-SA 4.0 许可协议

您正在寻找 sort.Reverse 。那会让你说:

 sort.Sort(sort.Reverse(fooAscending(s)))

原文由 cnicutar 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题