Go的sort包提供切片排序功能,支持基本类型如int、string通过sort.Ints、sort.Strings等函数直接排序;自定义排序推荐使用sort.Slice并传入比较函数,适用于结构体或逆序场景;复杂情况可实现sort.Interface接口的Len、Less、Swap方法以复用逻辑;所有排序均为原地修改。

在Go语言中,sort 包提供了对切片和用户自定义数据结构进行排序的高效方法。使用 sort 对切片排序非常直接,主要依赖于 sort.Sort 接口或更便捷的 sort.Slice 函数。
基本类型切片排序
对于常见的基本类型(如 int、string、float64),sort 包已经提供了预定义函数:
sort.Ints([]int):对整型切片升序排序 sort.Strings([]string):对字符串切片排序 sort.Float64s([]float64):对 float64 切片排序示例:
ints := []int{3, 1, 4, 1, 5}sort.Ints(ints)// 结果: [1 1 3 4 5]strs := []string{"banana", "apple", "cherry"}sort.Strings(strs)// 结果: ["apple" "banana" "cherry"]
使用 sort.Slice 自定义排序
当需要按自定义规则排序时,比如结构体或逆序排列,sort.Slice 是最方便的方式。它接受一个切片和一个比较函数。
示例:按结构体字段排序
type Person struct { Name string Age int}people := []Person{ {"Alice", 30}, {"Bob", 25}, {"Charlie", 35},}// 按年龄升序排序sort.Slice(people, func(i, j int) bool { return people[i].Age < people[j].Age})// 结果: Bob(25), Alice(30), Charlie(35)
若要降序,只需调整比较逻辑:
立即学习“go语言免费学习笔记(深入)”;
// 按名字长度降序sort.Slice(people, func(i, j int) bool { return len(people[i].Name) > len(people[j].Name)})
实现 sort.Interface 接口(高级用法)
对于复杂场景,可以为类型实现 sort.Interface 的三个方法:Len()、Less(i, j)、Swap(i, j)。
示例:
type ByAge []Personfunc (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 }sort.Sort(ByAge(people))
这种方式更灵活,适合需要复用排序逻辑的情况。
基本上就这些。日常开发中推荐优先使用 sort.Slice,简洁且足够强大。注意:所有排序都是原地操作,会修改原切片。
以上就是Golang如何使用sort对切片排序的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1410885.html
微信扫一扫
支付宝扫一扫