首頁 >後端開發 >Golang >如何按多個參數(姓氏然後名字)對 Go 中的結構進行排序?

如何按多個參數(姓氏然後名字)對 Go 中的結構進行排序?

Susan Sarandon
Susan Sarandon原創
2024-12-16 17:34:14620瀏覽

How to Sort Structs in Go by Multiple Parameters (LastName then FirstName)?

使用多個排序參數對結構進行排序

使用數組或結構體切片時,按多個參數對它們進行排序可能是常見要求。本指南探討了基於多個參數對結構體進行排序的不同方法,並著重於按 LastName 和 FirstName 排序的特定需求。

使用 slices.SortFunc 進行簡潔排序

在 Go 1.22 及更高版本中,slices.SortFunc 函數為切片排序提供了簡潔易讀的解決方案。它採用自訂比較函數作為參數,讓您可以定義排序標準。要按姓氏和名字排序,可以使用cmp.Or 和cmp.Compare 函數:

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.Slice 函數提供了一個對切片進行排序的簡單方法。它接受一個切片和一個比較函數作為參數。如果比較函數的第一個參數小於第二個參數,則比較函數應傳回 true,否則傳回 false。要按姓氏和名字排序,您可以建立以下比較函數:

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.Sort 函數,該函式接受一個實作sort.Interface 介面的值。此介面需要三個方法:Len()、Swap() 和 Less()。 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