golang使用sort接口实现排序示例

今天看见群里再讨论排序的sort.Interface的实现,有童鞋一直搞不定,我就上手了一下,哦耶搞定了,代码放在这里.

其实很简单sort.Interface借口有三个方法,给自己的struct实现这三个方法,然后用将自己的结构体传给sort.Sort方法就排序完成.

当然sort包也有几个常用的方法sort.Float64Slice sort.IntSlise sort.StringSlise,呵呵

package main
import (
    "fmt"
    "sort"
)
type MapSorter []Item
type Item struct {
    Key string
    Val int64
}
func NewMapSorter(m map[string]int64) MapSorter {
    ms := make(MapSorter, 0, len(m))
    for k, v := range m {
        ms = append(ms, Item{k, v})
    }
    return ms
}
func (ms MapSorter) Len() int {
    return len(ms)
}
func (ms MapSorter) Less(i, j int) bool {
    return ms[i].Val < ms[j].Val // 按值排序
    //return ms[i].Key < ms[j].Key // 按键排序
}
func (ms MapSorter) Swap(i, j int) {
    ms[i], ms[j] = ms[j], ms[i]
}
func main(){
    m  := map[string]int64 {
        "e": 10,
        "a": 2,
        "d": 15,
        "c": 8,
        "f": 1,
        "b": 12,
    }
    ms := NewMapSorter(m)
    sort.Sort(ms)
    for _, item := range ms {
        fmt.Printf("%s:%d\n", item.Key, item.Val)
    }
}
、、、、、、、、、、、、、、、、、、、、、、、
//对任意对象进行排序  
type Person struct {  
    name string  
    age  int  
}  
 
//为*Person添加String()方法,便于输出  
func (p *Person) String() string {  
    return fmt.Sprintf("( %s,%d )", p.name, p.age)  
}  
 
type PersonList []*Person  
 
//排序规则:首先按年龄排序(由小到大),年龄相同时按姓名进行排序(按字符串的自然顺序)  
 
func (list PersonList) Len() int {  
    return len(list)  
}  
 
func (list PersonList) Less(i, j int) bool {  
    if list[i].age < list[j].age {  
        return true  
    } else if list[i].age > list[j].age {  
        return false  
    } else {  
        return list[i].name < list[j].name  
    }  
}  
 
func (list PersonList) Swap(i, j int) {  
    var temp *Person = list[i]  
    list[i] = list[j]  
    list[j] = temp  
}  
 
func interfaceTest0203() {  
    fmt.Println("------")  
    p1 := &Person{"Tom", 19}  
    p2 := &Person{"Hanks", 19}  
    p3 := &Person{"Amy", 19}  
    p4 := &Person{"Tom", 20}  
    p5 := &Person{"Jogn", 21}  
    p6 := &Person{"Mike", 23}  
 
    pList := PersonList([]*Person{p1, p2, p3, p4, p5, p6})  
    sort.Sort(pList)  
    fmt.Println(pList)  
 
    /*output:  
    [( Amy,19 ) ( Hanks,19 ) ( Tom,19 ) ( Tom,20 ) ( Jogn,21 ) ( Mike,23 )] */  
}

原文发布于微信公众号 - Golang语言社区(Golangweb)

原文发表时间:2017-05-07

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏友弟技术工作室

golang之Struct什么是结构体struct?

最近在复习golang,学习的东西,如果不使用,很快就会忘记。所以,准备复习完golang,做一个练手的小项目,加深对golang的学习。今天开始公司,进入封闭...

62160
来自专栏wym

2013年多校赛 hdu4607

   那么就考虑树上最长距离,树的直径, 如果访问的点大于树的直径就要走回头路,答案即多的数乘2加上原来树的直径

13350
来自专栏Golang语言社区

浅谈Go语言中的结构体struct &amp; 接口Interface &amp; 反射

结构体struct struct 用来自定义复杂数据结构,可以包含多个字段(属性),可以嵌套;

25140
来自专栏java达人

数字的陷阱

Java中对数字的处理,如四舍五入,如加减乘除,貌似是一个很基础很简单的知识点,但是如果你没有对他进行充分了解,很容易掉进它的陷阱里。 1、浮点数运算 先来看一...

19880
来自专栏小樱的经验随笔

Codeforces 842A Kirill And The Game【暴力,水】

A. Kirill And The Game time limit per test:2 seconds memory limit per test:256 m...

29570
来自专栏GreenLeaves

C# String.Format的格式限定符与Format方法将多个对象格式化一个字符串原理

Format方法将多个对象格式化成一个字符串Format方法解析格式字符串的原理:

14720
来自专栏分布式系统和大数据处理

.Net中的反射(动态创建类型实例) - Part.4

在前面节中,我们先了解了反射,然后利用反射查看了类型信息,并学习了如何创建自定义特性,并利用反射来遍历它。可以说,前面三节,我们学习的都是反射是什么,在接下来的...

15530
来自专栏blackheart的专栏

[C#1] 7-枚举

1.Enum 枚举是定义了一组符号名称和数值对,如下: 1 //byte、sbyte、short、ushort、int、uint、long 或 ulong ...

232100
来自专栏進无尽的文章

编码篇 - 正则表达式及其相关

有时我们需要在一大段长文本中过滤出我们需要的字段,或者检验该文本是否符合要求(该文本是否是邮箱,链接,电话号码或身份证),这时候就需要用到正则表达式了,当然我们...

12520
来自专栏CaiRui

Python列表知识补充

1、import this  Python之禅,圣经。 >>> import this The Zen of Python, by Tim Peters Be...

22390

扫码关注云+社区

领取腾讯云代金券