登录
首页 >  Golang >  Go问答

Go sort.IntSlice() 实现

来源:stackoverflow

时间:2024-04-05 08:36:33 244浏览 收藏

最近发现不少小伙伴都对Golang很感兴趣,所以今天继续给大家介绍Golang相关的知识,本文《Go sort.IntSlice() 实现》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

问题内容

我正在寻找如何对 go 数组进行反向排序:

sort.Sort(sort.Reverse(sort.IntSlice(s))) // s is the slice of ints

我在 https://godoc.org/sort 查看了 go 文档的 sort pkg

我看到有一种 intslice 类型,但没有用于排序包的 intslice() 方法

有人可以解释一下 intslice() 是如何实现的或者为什么它不在排序包中吗?


解决方案


因此,在写出这个问题时,我查看了 type IntSlice 源代码,并意识到 IntSlice() 不是 sort pkg 的函数,而是 []int 的别名,因此 sort.IntSlice(s) 将 slice s 转换为输入 IntSlice。

之所以需要将[]int转换为IntSlice类型,是因为sort.Reverse()需要一个Interface类型,并且必须实现[]int没有实现的Len()、Swap()、Less()。

这也让我想起 Donovan 和 Kernighan 写的关于接口的另一点,我们可能无法修改具体类型,但我们可以通过接口扩展功能,这让我意识到这是一个示例 b/c []int 是作为 Go 语言规范一部分的底层类型,但 sort pkg 通过 Interface 接口扩展行为。

到这里,我们也就讲完了《Go sort.IntSlice() 实现》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>