詳解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)為[]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ù),對(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中context包使用場(chǎng)景和示例詳解
這篇文章結(jié)合示例代碼介紹了context包的幾種使用場(chǎng)景,文中有詳細(xì)的代碼示例,對(duì)學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2023-05-05詳解Go語(yǔ)言中init的使用與常見(jiàn)應(yīng)用場(chǎng)景
Go?中有一個(gè)特別的?init()?函數(shù),它主要用于包的初始化,這篇文章將以此為主題介紹?Go?中?init()?函數(shù)的使用和常見(jiàn)使用場(chǎng)景,希望對(duì)大家有所幫助2024-02-02golang文件內(nèi)容覆蓋問(wèn)題的分析及解決
通過(guò)golang讀取數(shù)據(jù)庫(kù)站點(diǎn)映射配置,生成nginx conf文件,并檢查和重啟nginx服務(wù),已達(dá)到站點(diǎn)自動(dòng)化部署目的,當(dāng)目標(biāo)文件中內(nèi)容很長(zhǎng),而寫(xiě)入的內(nèi)容很短時(shí),目標(biāo)文件內(nèi)容無(wú)法完全覆蓋,本文給大家介紹了解決方法,需要的朋友可以參考下2024-01-01go?build失敗報(bào)方法undefined的解決過(guò)程
go build命令用于編譯我們指定的源碼文件或代碼包以及它們的依賴(lài)包,下面這篇文章主要給大家介紹了關(guān)于go?build失敗報(bào)方法undefined的解決過(guò)程,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11go獲取協(xié)程(goroutine)號(hào)的實(shí)例
這篇文章主要介紹了go獲取協(xié)程(goroutine)號(hào)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12使用自定義錯(cuò)誤碼攔截grpc內(nèi)部狀態(tài)碼問(wèn)題
這篇文章主要介紹了使用自定義錯(cuò)誤碼攔截grpc內(nèi)部狀態(tài)碼問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09Golang實(shí)現(xiàn)基于Redis的可靠延遲隊(duì)列
redisson?delayqueue可以使用redis的有序集合結(jié)構(gòu)實(shí)現(xiàn)延時(shí)隊(duì)列,遺憾的是go語(yǔ)言社區(qū)中并無(wú)類(lèi)似的庫(kù)。不過(guò)問(wèn)題不大,本文將用Go語(yǔ)言實(shí)現(xiàn)這一功能,需要的可以參考一下2022-06-06golang中判斷請(qǐng)求是http還是https獲取當(dāng)前訪問(wèn)地址
這篇文章主要為大家介紹了golang中判斷請(qǐng)求是http還是https獲取當(dāng)前訪問(wèn)地址示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說(shuō)明
這篇文章主要介紹了Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12