首页 >后端开发 >Golang >Go 中如何按多个参数对结构体进行排序?

Go 中如何按多个参数对结构体进行排序?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-16 12:20:11323浏览

How to Sort Structs by Multiple Parameters in Go?

使用多个参数对结构体进行排序

问题:

结构体数组如何排序按多个参数排序,特别是按姓氏,然后是名字Go?

答案:

Go 中有多种对具有多个参数的结构体进行排序的方法。

Go 1.22 中使用 slices.SortFunc

Go 的最新版本(1.22 及更高版本)提供了使用 slices.SortFunc 的简洁解决方案:

slices.SortFunc(members, func(a, b Member) int {
    return cmp.Or(
        cmp.Compare(a.LastName, b.LastName),
        cmp.Compare(a.FirstName, b.FirstName),
    )
})

sort.Slice 或 sort.Sort 函数

对于早期版本的 Go,请考虑使用 sort.Slice 或 sort.Sort。两者都需要一个自定义的 less 函数来根据所需参数确定排序。

使用 sort.Slice:

sort.Slice(members, func(i, j int) bool {
    if members[i].LastName != members[j].LastName {
        return members[i].LastName < members[j].LastName
    }
    return members[i].FirstName < members[j].FirstName
})

使用 sort.Sort:

创建一个实现sort.Interface接口的自定义类型,定义Len,交换和 Less 方法。

type byLastFirst []Member

func (members byLastFirst) Len() int           { return len(members) }
func (members byLastFirst) Swap(i, j int)      { members[i], members[j] = members[j], members[i] }
func (members byLastFirst) Less(i, j int) bool {
    if members[i].LastName != members[j].LastName {
        return members[i].LastName < members[j].LastName
    }
    return members[i].FirstName < members[j].FirstName
}

sort.Sort(byLastFirst(members))

性能注意事项:

虽然这些方法提供了不同的结构排序方法,但性能分析对于优化热点至关重要。选择最适合您的应用程序要求的方法。

以上是Go 中如何按多个参数对结构体进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn