詳解Go語言如何使用標(biāo)準(zhǔn)庫sort對切片進(jìn)行排序
sort 標(biāo)準(zhǔn)庫
Sort 標(biāo)準(zhǔn)庫提供了對基本數(shù)據(jù)類型的切片和自定義類型的切片進(jìn)行排序的函數(shù),常用函數(shù)如下表所示:
函數(shù) | 描述 |
---|---|
Ints(x []int) | 對 int 類型的切片進(jìn)行升序排序 |
IntsAreSorted(x []int) bool | 判斷 int 類型的切片是否是升序排序 |
Float64s(x []float64) | 對 float64 類型的切片進(jìn)行升序排序 |
Float64sAreSorted(x []float64) bool | 判斷 float64 類型的切片是否是升序排序 |
Strings(x []string) | 對 string 類型的切片進(jìn)行升序排序 |
StringsAreSorted(x []string) bool | 判斷 string 類型的切片是否是升序排序 |
Sort(data Interface) | 對自定義類型的切片進(jìn)行排序,自定義類型必須實(shí)現(xiàn) Interface 接口 |
如果想了解更多函數(shù)的介紹和使用,可以到 pkg.go.dev/sort 進(jìn)行查看。
Ints 和 IntsAreSorted
Ints(x []int)
:對 int
類型的切片進(jìn)行排序,將切片作為參數(shù)進(jìn)行傳遞,改變原切片的元素順序
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)
:對 float64
類型的切片進(jìn)行排序,將切片作為參數(shù)進(jìn)行傳遞,改變原切片的元素順序
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)
:對 float64
類型的切片進(jìn)行排序,將切片作為參數(shù)進(jìn)行傳遞,改變原切片的元素順序
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)
:對實(shí)現(xiàn) Interface
接口的自定義集合類型按照自定義的規(guī)則進(jìn)行排序。
Interface
實(shí)現(xiàn) Interface
接口,需要實(shí)現(xiàn)以下三個(gè)方法:
Len() int
返回集合的長度
Less(i, j) bool
i
和j
為兩個(gè)元素在集合里的下標(biāo)值- 該方法返回一個(gè)
bool
值, 判斷i
位置的元素是否應(yīng)該排在j
之前,如果bool
值為false
,則說明i
不應(yīng)該在j
之前。
Swap(i, j int)
對結(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
類型,其基類為[]User
User
切片 - 實(shí)現(xiàn)
sort
包里的Interface
接口,定義Len
、Less
和Swap
函數(shù) Less
函數(shù)的返回值邏輯為return us[i].Age < us[j].Age
,表示按照年齡字段進(jìn)行升序排序
小結(jié)
本文介紹了如何使用 sort
包里的函數(shù),對基本數(shù)據(jù)類型的切片進(jìn)行排序。sort
包還提供了對自定義的集合進(jìn)行排序,需要實(shí)現(xiàn) Interface
接口,由使用者去自定義排序規(guī)則,通過 sort.Sort
函數(shù)進(jìn)行排序。
到此這篇關(guān)于詳解Go語言如何使用標(biāo)準(zhǔn)庫sort對切片進(jìn)行排序的文章就介紹到這了,更多相關(guān)Go語言sort切片排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
go?build失敗報(bào)方法undefined的解決過程
go build命令用于編譯我們指定的源碼文件或代碼包以及它們的依賴包,下面這篇文章主要給大家介紹了關(guān)于go?build失敗報(bào)方法undefined的解決過程,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11go獲取協(xié)程(goroutine)號的實(shí)例
這篇文章主要介紹了go獲取協(xié)程(goroutine)號的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12使用自定義錯(cuò)誤碼攔截grpc內(nèi)部狀態(tài)碼問題
這篇文章主要介紹了使用自定義錯(cuò)誤碼攔截grpc內(nèi)部狀態(tài)碼問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09Golang實(shí)現(xiàn)基于Redis的可靠延遲隊(duì)列
redisson?delayqueue可以使用redis的有序集合結(jié)構(gòu)實(shí)現(xiàn)延時(shí)隊(duì)列,遺憾的是go語言社區(qū)中并無類似的庫。不過問題不大,本文將用Go語言實(shí)現(xiàn)這一功能,需要的可以參考一下2022-06-06golang中判斷請求是http還是https獲取當(dāng)前訪問地址
這篇文章主要為大家介紹了golang中判斷請求是http還是https獲取當(dāng)前訪問地址示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說明
這篇文章主要介紹了Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說明,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12