Golang 多重排序

结构体定义

type A struct {
	xx int,
	yy int,
	zz int,
}

重写排序方法

type Wrapper struct {
	a []*A
	by     func(p, q *A) bool
}

type SortBy func(p, q *A) bool

func (pw Wrapper) Len() int { // 重写 Len() 方法
	return len(pw.a)
}
func (pw Wrapper) Swap(i, j int) { // 重写 Swap() 方法
	pw.a[i], pw.a[j] = pw.a[j], pw.a[i]
}
func (pw Wrapper) Less(i, j int) bool { // 重写 Less() 方法
	return pw.by(pw.a[i], pw.a[j])
}

自定义规则

func GetSortByAA(a []*Topics) []*A {
	sort.Sort(Wrapper{a, func(p, q *A) bool {
		if p.yy > q.yy {
			return true
		} else {
			if p.ww == q.ww {
				if p.xx < q.xx {
					return true
				} else if p.xx == q.xx {
					return p.zz > q.zz
				} else {
					return false
				}
			} else {
				return false
			}
		}
	}})
	return topics
}
func GetSortByAAAA(result []*A) []*A {
	sort.Sort(Wrapper{result, func(p, q *A) bool {
		if p.xx > q.xx {
			return true
		} else {
			if p.xx == q.xx {
				if p.yy < q.yy {
					return true
				} else {
					if p.zz == q.zz {
						return p.UpdateAt.After(q.UpdateAt)
					}
				}
			} else {
				return false
			}
		}
		return false
	}})
	return result
}

使用方法

var a = make([]*A, 0,10)
GetSortByArticleCount(a)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值