詳解Go語(yǔ)言如何使用標(biāo)準(zhǔn)庫(kù)sort對(duì)切片進(jìn)行排序
sort 標(biāo)準(zhǔn)庫(kù)
Sort 標(biāo)準(zhǔn)庫(kù)提供了對(duì)基本數(shù)據(jù)類(lèi)型的切片和自定義類(lèi)型的切片進(jìn)行排序的函數(shù),常用函數(shù)如下表所示:
| 函數(shù) | 描述 |
|---|---|
| Ints(x []int) | 對(duì) int 類(lèi)型的切片進(jìn)行升序排序 |
| IntsAreSorted(x []int) bool | 判斷 int 類(lèi)型的切片是否是升序排序 |
| Float64s(x []float64) | 對(duì) float64 類(lèi)型的切片進(jìn)行升序排序 |
| Float64sAreSorted(x []float64) bool | 判斷 float64 類(lèi)型的切片是否是升序排序 |
| Strings(x []string) | 對(duì) string 類(lèi)型的切片進(jìn)行升序排序 |
| StringsAreSorted(x []string) bool | 判斷 string 類(lèi)型的切片是否是升序排序 |
| Sort(data Interface) | 對(duì)自定義類(lèi)型的切片進(jìn)行排序,自定義類(lèi)型必須實(shí)現(xiàn) Interface 接口 |
如果想了解更多函數(shù)的介紹和使用,可以到 pkg.go.dev/sort 進(jìn)行查看。
Ints 和 IntsAreSorted
Ints(x []int):對(duì) int 類(lèi)型的切片進(jìn)行排序,將切片作為參數(shù)進(jìn)行傳遞,改變?cè)衅脑仨樞?/p>
IntsAreSorted(x []int) bool,傳遞一個(gè)切片進(jìn)去,判斷此切片是否是升序排序,是則返回 true,否則返回 false。
import (
"fmt"
"sort"
)
func main() {
nums := []int{5, 3, 1, 2, 4, 7}
fmt.Println("排序前:", nums)
fmt.Println("切片是否是升序排序:", sort.IntsAreSorted(nums))
sort.Ints(nums)
fmt.Println("排序后:", nums)
fmt.Println("切片是否是升序排序:", sort.IntsAreSorted(nums))
}
執(zhí)行結(jié)果:
排序前: [5 3 1 2 4 7]
切片是否是升序排序: false
排序后: [1 2 3 4 5 7]
切片是否是升序排序: true
Float64s 和 Float64sAreSorted
Float64s(x []float64):對(duì) float64 類(lèi)型的切片進(jìn)行排序,將切片作為參數(shù)進(jìn)行傳遞,改變?cè)衅脑仨樞?/p>
Float64sAreSorted(x []float64) bool,傳遞一個(gè)切片進(jìn)去,判斷此切片是否是升序排序,是則返回 true,否則返回 false。
import (
"fmt"
"sort"
)
func main() {
nums := []float64{0.0, 1.5, 1.0, 2.4, 4.4, 7.3}
fmt.Println("排序前:", nums)
fmt.Println("切片是否是升序排序:", sort.Float64sAreSorted(nums))
sort.Float64s(nums)
fmt.Println("排序后:", nums)
fmt.Println("切片是否是升序排序:", sort.Float64sAreSorted(nums))
}執(zhí)行結(jié)果:
排序前: [0 1.5 1 2.4 4.4 7.3]
切片是否是升序排序: false
排序后: [0 1 1.5 2.4 4.4 7.3]
切片是否是升序排序: true
Strings 和 StringsAreSorted
Strings(x []string):對(duì) float64 類(lèi)型的切片進(jìn)行排序,將切片作為參數(shù)進(jìn)行傳遞,改變?cè)衅脑仨樞?/p>
StringsAreSorted(x []string) bool,傳遞一個(gè)切片進(jìn)去,判斷此切片是否是升序排序,是則返回 true,否則返回 false。
import (
"fmt"
"sort"
)
func main() {
strs := []string{"d", "a", "c", "b"}
fmt.Println("排序前:", strs)
fmt.Println("切片是否是升序排序:", sort.StringsAreSorted(strs))
sort.Strings(strs)
fmt.Println("排序后:", strs)
fmt.Println("切片是否是升序排序:", sort.StringsAreSorted(strs))
}執(zhí)行結(jié)果:
排序前: [d a c b]
切片是否是升序排序: false
排序后: [a b c d]
切片是否是升序排序: true
Sort
Sort(data Interface):對(duì)實(shí)現(xiàn) Interface 接口的自定義集合類(lèi)型按照自定義的規(guī)則進(jìn)行排序。
Interface
實(shí)現(xiàn) Interface 接口,需要實(shí)現(xiàn)以下三個(gè)方法:
Len() int 返回集合的長(zhǎng)度
Less(i, j) bool
i和j為兩個(gè)元素在集合里的下標(biāo)值- 該方法返回一個(gè)
bool值, 判斷i位置的元素是否應(yīng)該排在j之前,如果bool值為false,則說(shuō)明i不應(yīng)該在j之前。
Swap(i, j int)
對(duì)結(jié)構(gòu)體切片進(jìn)行排序
import (
"fmt"
"sort"
)
type User struct {
Name string
Age int
}
type UserSlice []User
func (us UserSlice) Len() int {
return len(us)
}
func (us UserSlice) Less(i, j int) bool {
return us[i].Age < us[j].Age
}
func (us UserSlice) Swap(i, j int) {
us[i], us[j] = us[j], us[i]
}
func main() {
us := UserSlice{
User{Name: "小明", Age: 22},
User{Name: "小紅", Age: 17},
User{Name: "小花", Age: 18},
}
fmt.Println("排序前:", us)
sort.Sort(us)
fmt.Println("排序后:", us)
}執(zhí)行結(jié)果:
排序前: [{小明 22} {小紅 17} {小花 18}]
排序后: [{小紅 17} {小花 18} {小明 22}]
- 定義
User結(jié)構(gòu)體,自定義UserSlice類(lèi)型,其基類(lèi)為[]UserUser切片 - 實(shí)現(xiàn)
sort包里的Interface接口,定義Len、Less和Swap函數(shù) Less函數(shù)的返回值邏輯為return us[i].Age < us[j].Age,表示按照年齡字段進(jìn)行升序排序
小結(jié)
本文介紹了如何使用 sort 包里的函數(shù),對(duì)基本數(shù)據(jù)類(lèi)型的切片進(jìn)行排序。sort 包還提供了對(duì)自定義的集合進(jìn)行排序,需要實(shí)現(xiàn) Interface 接口,由使用者去自定義排序規(guī)則,通過(guò) sort.Sort 函數(shù)進(jìn)行排序。
到此這篇關(guān)于詳解Go語(yǔ)言如何使用標(biāo)準(zhǔn)庫(kù)sort對(duì)切片進(jìn)行排序的文章就介紹到這了,更多相關(guān)Go語(yǔ)言sort切片排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Golang中函數(shù)(Function)和方法(Method)的區(qū)別詳解
在Golang中,大家必然會(huì)頻繁使用到函數(shù)(Function)和方法(Method),但是有的同學(xué)可能并沒(méi)有注意過(guò)函數(shù)和方法的異同點(diǎn),函數(shù)和方法都是用來(lái)執(zhí)行特定任務(wù)的代碼塊,雖然很相似,但也有很大的區(qū)別,所以本文將詳細(xì)講解函數(shù)和方法的定義以及它們的異同點(diǎn)2023-07-07
Golang Http 驗(yàn)證碼示例實(shí)現(xiàn)
這篇文章主要介紹了Golang Http 驗(yàn)證碼示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
Golang Model 字段自動(dòng)化校驗(yàn)設(shè)計(jì)方案
在我們?nèi)粘i_(kāi)發(fā)中,不可避免的總要去進(jìn)行各種參數(shù)校驗(yàn),但是如果在某個(gè)場(chǎng)景中,要校驗(yàn)的字段非常多,并且在其中還有耦合關(guān)系,那么我們手寫(xiě)校驗(yàn)邏輯就變得非常的低效且難以維護(hù),本篇文檔就基于 DDD 領(lǐng)域模型設(shè)計(jì)的思想下,提供自動(dòng)化的校驗(yàn)?zāi)P妥侄?感興趣的朋友一起看看吧2025-02-02
Golang動(dòng)態(tài)數(shù)組的實(shí)現(xiàn)示例
動(dòng)態(tài)數(shù)組能自動(dòng)調(diào)整大小,與靜態(tài)數(shù)組不同,其大小不固定,可根據(jù)需求變化,實(shí)現(xiàn)通常依賴(lài)于數(shù)據(jù)結(jié)構(gòu)如鏈表或數(shù)組加額外信息,本文就來(lái)介紹一下Golang動(dòng)態(tài)數(shù)組的實(shí)現(xiàn)示例,感興趣的可以了解一下2024-10-10
詳解Golang中NewTimer計(jì)時(shí)器的底層實(shí)現(xiàn)原理
本文將主要介紹一下Go語(yǔ)言中的NewTimer,首先展示基于NewTimer創(chuàng)建的定時(shí)器來(lái)實(shí)現(xiàn)超時(shí)控制。接著通過(guò)一系列問(wèn)題的跟進(jìn),展示了NewTimer的底層實(shí)現(xiàn)原理,需要的可以參考一下2023-05-05

