如何使用Golang sort包排序数据_sort Slice与Ints用法
发布时间 - 2026-01-29 00:00:00 点击率:次Go sort包排序需显式指定规则:整数切片用sort.Ints;自定义类型须实现sort.Interface三方法;sort.Slice支持闭包但不稳定,sort.SliceStable才稳定且更推荐。
Go 的 sort 包不提供“自动推导类型”的泛型排序(在 Go 1.18 之前),所以对 slice 排序必须明确告诉它怎么比——要么用预置函数(如 sort.Ints),要么自己写 Less 逻辑。直接调 sort.Sort 不会报错但可能没效果,因为没实现 sort.Interface。
用 sort.Ints 快速排整数切片
这是最省事的方式,专为 []int 设计,原地升序排列,无需额外定义类型或方法。
- 只接受
[]int,传[]int64或[]float6会编译失败
4
- 修改原 slice,不返回新 slice;如果需要保留原数据,先
copy - 底层用的是优化过的快排+插排混合算法,性能可靠
nums := []int{3, 1, 4, 1, 5}
sort.Ints(nums)
// nums == []int{1, 1, 3, 4, 5}
对自定义 struct slice 排序必须实现 sort.Interface
Go 不支持像 Python 的 key= 那样传匿名函数,所以得让类型满足 Len()、Less(i,j int) bool、Swap(i,j int) 三个方法。常见写法是定义一个命名类型别名再实现:
- 不能直接在匿名 struct 上实现方法(语法不允许)
- 如果只是临时排序,可定义局部类型,比如
type ByName []User -
Less返回true表示 “i 应该排在 j 前面”,不是 “i 小于 j” —— 这点容易反直觉
type User struct {
Name string
Age int
}
type ByAge []User
func (a ByAge) Len() int { return len(a) }
func (a ByAge) Less(i, j int) bool { return a[i].Age < a[j].Age }
func (a ByAge) Swap(i, j int) { a[i], a[j] = a[j], a[i] }
users := []User{{"Alice", 30}, {"Bob", 25}}
sort.Sort(ByAge(users)) // 升序按 Age
用 sort.Slice(Go 1.8+)替代手写接口
这是更现代、更轻量的方案:不用定义新类型,直接传 slice 和一个闭包函数描述比较逻辑。它内部会动态构造临时适配器,语义清晰且不易出错。
- 支持任意 slice 类型,包括
[]*T、[]map[string]interface{}等复杂情况 - 闭包里访问元素用
s[i]、s[j],和平时写法一致,不用记Less的 i/j 顺序 - 注意:闭包捕获外部变量时要小心循环变量陷阱(比如在 for 循环里用
range索引生成多个sort.Slice调用)
users := []User{{"Alice", 30}, {"Bob", 25}}
sort.Slice(users, func(i, j int) bool {
return users[i].Age < users[j].Age // 升序
})
// 或按 Name 降序:
sort.Slice(users, func(i, j int) bool {
return users[i].Name > users[j].Name
})
常见坑:sort.SliceStable 和 sort.Stable 的区别
稳定排序(stable sort)指相等元素的原始相对顺序不变。如果你依赖这个行为(比如先按 age 排、再按 name 排还想保持 age 相同时 name 的原有次序),就得选带 Stable 的版本。
-
sort.Slice是不稳定的;sort.SliceStable才稳定 -
sort.Stable要求你仍实现sort.Interface,而sort.SliceStable同样接受闭包,更推荐 - 稳定排序有轻微性能开销,非必要不强求
多数业务场景里,sort.Slice 足够用;只有当你明确需要“相等键值不打乱原始顺序”时,才切到 sort.SliceStable。
# python
# go
# golang
# 区别
# 排列
# less
# String
# sort
# for
# bool
# int
# 循环
# 接口
# Struct
# Interface
# 泛型
# 闭包
# 切片
# len
# copy
# map
# 算法
# 升序
# 这是
# 自定义
# 的是
# 如果你
# 多个
# 当你
# 不支持
# 就得
# 还想
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel怎么在Blade中安全地输出原始HTML内容
如何快速查询域名建站关键信息?
实例解析Array和String方法
javascript中对象的定义、使用以及对象和原型链操作小结
消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工
今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】
如何在云主机上快速搭建网站?
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
微信小程序 wx.uploadFile无法上传解决办法
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
如何用搬瓦工VPS快速搭建个人网站?
Laravel中间件如何使用_Laravel自定义中间件实现权限控制
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
Laravel如何使用Service Provider服务提供者_Laravel依赖注入与容器绑定【深度】
Laravel如何操作JSON类型的数据库字段?(Eloquent示例)
如何快速生成ASP一键建站模板并优化安全性?
如何正确下载安装西数主机建站助手?
laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法
Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】
智能起名网站制作软件有哪些,制作logo的软件?
如何在云虚拟主机上快速搭建个人网站?
详解jQuery停止动画——stop()方法的使用
详解jQuery中基本的动画方法
香港服务器如何优化才能显著提升网站加载速度?
JS中对数组元素进行增删改移的方法总结
Laravel怎么实现支付功能_Laravel集成支付宝微信支付
网站优化排名时,需要考虑哪些问题呢?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
高性能网站服务器部署指南:稳定运行与安全配置优化方案
开心动漫网站制作软件下载,十分开心动画为何停播?
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权
Laravel怎么在Controller之外的地方验证数据
Laravel Admin后台管理框架推荐_Laravel快速开发后台工具
Laravel如何处理异常和错误?(Handler示例)
如何快速使用云服务器搭建个人网站?
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
Swift中swift中的switch 语句
如何用花生壳三步快速搭建专属网站?
微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】
详解jQuery中的事件
Linux网络带宽限制_tc配置实践解析【教程】
Linux后台任务运行方法_nohup与&使用技巧【技巧】
非常酷的网站设计制作软件,酷培ai教育官方网站?
简历没回改:利用AI润色让你的文字更专业


