欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Golang 高效排序數(shù)據(jù)詳情

 更新時間:2021年11月10日 09:47:28   作者:frank  
本文我們介紹了怎么使用 Golang 語言標準庫 sort 包排序數(shù)據(jù),需要注意的是,除了本文使用的類型之外,其它任意類型只要實現(xiàn) sort.Interface 的三個方法,都可以調(diào)用 sort.Sort() 函數(shù)排序數(shù)據(jù)。

1.介紹

Golang 語言項目開發(fā)中,經(jīng)常會遇到數(shù)據(jù)排序問題。Golang 語言標準庫 sort 包,為我們提供了數(shù)據(jù)排序的功能,我們可以直接使用 sort.Sort() 函數(shù)進行數(shù)據(jù)排序,sort.Sort() 函數(shù)底層實現(xiàn)是以快排為主,并根據(jù)目標數(shù)據(jù)的具體情況選擇不同的排序算法。本文我們介紹 sort 包排序數(shù)據(jù)的使用方法。

2.切片排序

Golang 語言標準庫 sort 包中,sort.Sort() 函數(shù)用于數(shù)據(jù)排序,該函數(shù)需要一個 interface 類型的入?yún)?sort.Interface,它包含三個方法,分別是 Len() ,Less() Swap() 。也就是說,如果我們需要使用 sort 包的 Sort 函數(shù)進行數(shù)據(jù)排序,首先入?yún)⒌臄?shù)據(jù)需要實現(xiàn)這三個方法,或者理解為任意元素類型的切片實現(xiàn)了這三個方法,都可以使用 sort.Sort() 函數(shù)排序數(shù)據(jù)。

sort 包代碼:

type Interface interface { 
 Len() int // 集合中元素的數(shù)量 
 Less(i, j int) bool // 描述元素的順序 
 Swap(i, j int) // 交換索引為 i 和 j 的元素 
} 
 
func Sort(data Interface) 

需要注意的是 sort.Sort() 函數(shù)不能保證數(shù)據(jù)排序是穩(wěn)定的,如果需要保證數(shù)據(jù)排序穩(wěn)定,可以使用 sort.Stable() 函數(shù),“穩(wěn)定”的含義是原始數(shù)據(jù)中 a 和 b 的值相等,排序前 a 排在 b 的前面,排序后 a 仍排在 b 的前面。

為了方便讀者朋友們理解,我們使用 int 類型的切片作為示例,介紹 sort.Sort() 函數(shù)的使用方法,我們定義一個類型 type IntSlice []int,并且給類型 IntSlice 實現(xiàn) sort.Interface 接口類型定義的三個方法,然后使用 sort.Sort() 函數(shù)排序數(shù)據(jù)。

示例代碼:

package main 
 
import ( 
 "fmt" 
 "sort" 
) 
 
type IntSlice []int 
 
func (s IntSlice) Len() int { 
 return len(s) 
} 
 
func (s IntSlice) Less(i, j int) bool { 
 return s[i] > s[j] 
} 
 
func (s IntSlice) Swap(i, j int) { 
 s[i], s[j] = s[j], s[i] 
} 
 
func main () { 
 intSlice := IntSlice([]int{1, 3, 5, 7, 9}) 
 fmt.Println(intSlice) // 排序前 
 sort.Sort(intSlice) 
 fmt.Println(intSlice) // 排序后 
} 

輸出結構:

[9 7 5 3 1]
 
[1 3 5 7 9]

讀到這里,我相信聰明的讀者朋友們已經(jīng)了解了 sort.Sort() 的使用方式,同時也會產(chǎn)生一個疑問,難道每次使用 sort.Sort() 排序數(shù)據(jù),都需要這么麻煩嗎?我還不如自己寫個遍歷排序數(shù)據(jù)。

是的,當然不用這么麻煩,sort 包已經(jīng)幫我們封裝好了常用函數(shù),我們直接使用就可以了。所以,上面的示例代碼可以使用 sort.Ints() 函數(shù)排序數(shù)據(jù)。

示例代碼:

func main () { 
 intSlice := IntSlice([]int{9, 7, 5, 3, 1}) 
 fmt.Println(intSlice) // 排序前 
 sort.Ints(intSlice) 
 fmt.Println(intSlice) // 使用 sort.Ints() 排序數(shù)據(jù) 
} 

除了 sort.Ints() ,還有 sort.Float64s() ,sort.Strings()等。

3.自定義集合排序

Golang 語言項目開發(fā)中,我們經(jīng)常會使用結構體,如果我們需要排序結構體類型的切片,應該怎么操作呢?

我們可以按照 Part 01 介紹的方式,實現(xiàn)那三個方法,然后調(diào)用 sort.Sort() 函數(shù),當然,sort 包也為我們封裝了排序結構體類型切片的函數(shù) sort.Slice() ,但是,參數(shù)除了需要排序的數(shù)據(jù)之外,還需要提供一個 Less() 函數(shù)類型的參數(shù)。

示例代碼:

people := []struct { 
  Name string 
  Age  int 
 }{ 
  {"Gopher", 7}, 
  {"Alice", 55}, 
  {"Vera", 24}, 
  {"Bob", 75}, 
 } 
 sort.Slice(people, func(i, j int) bool { return people[i].Name < people[j].Name }) 
 fmt.Println("By name:", people) 
 
 sort.Slice(people, func(i, j int) bool { return people[i].Age < people[j].Age }) 
 fmt.Println("By age:", people) 

輸出結果:

By name: [{Alice 55} {Bob 75} {Gopher 7} {Vera 24}]
 
By age: [{Gopher 7} {Vera 24} {Alice 55} {Bob 75}]

4總結

本文我們介紹了怎么使用 Golang 語言標準庫 sort 包排序數(shù)據(jù),需要注意的是,除了本文使用的類型之外,其它任意類型只要實現(xiàn) sort.Interface 的三個方法,都可以調(diào)用 sort.Sort() 函數(shù)排序數(shù)據(jù)。

到此這篇關于Golang 高效排序數(shù)據(jù)詳情的文章就介紹到這了,更多相關Golang 高效排序數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Golang常用的幾種密碼加密方式分享

    Golang常用的幾種密碼加密方式分享

    這篇文章給大家介紹了Golang常用的幾種密碼加密方式,加密有兩種方式,一種是直接加密,一種是鹽值加密,直接加密指的是將原始密碼直接進行加密,鹽值加密則是在進行密碼加密之前,文中有詳細的代碼示例,需要的朋友可以參考下
    2023-08-08
  • Go語言中利用http發(fā)起Get和Post請求的方法示例

    Go語言中利用http發(fā)起Get和Post請求的方法示例

    這篇文章主要給大家介紹了關于Go語言中利用http發(fā)起Get和Post請求的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-11-11
  • Go語言中的自定義類型你了解嗎

    Go語言中的自定義類型你了解嗎

    自定義類型是 Go 語言中非常重要的概念之一,通過自定義類型,我們可以更好地封裝數(shù)據(jù)、組織代碼,提高程序的可讀性和可維護性。本文將從以下幾個方面介紹 Go 自定義類型的相關知識,感興趣的可以了解一下
    2023-04-04
  • Golang通脈之方法詳情

    Golang通脈之方法詳情

    這篇文章主要介紹了Golang通脈方法,Go語言中的方法(Method)是一種作用于特定類型變量的函數(shù)。這種特定類型變量叫做接收者(Receiver)。接收者的概念就類似于,其他語言中的this或者 self,具體內(nèi)容請和小編一起來學習下面文章內(nèi)容吧
    2021-10-10
  • Go語言獲取數(shù)組長度的方法

    Go語言獲取數(shù)組長度的方法

    這篇文章主要介紹了Go語言獲取數(shù)組長度的方法,實例分析了len函數(shù)的使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-02-02
  • Go語言HTTPServer開發(fā)的六種方式小結

    Go語言HTTPServer開發(fā)的六種方式小結

    Golang的Server開發(fā)顯得非常簡單,有很多種方式,本文就介紹了Go語言HTTPServer開發(fā)的六種方式,具有一定的參考價值,感興趣的可以了解一下
    2021-11-11
  • 一文帶你搞懂Golang結構體內(nèi)存布局

    一文帶你搞懂Golang結構體內(nèi)存布局

    結構體在Go語言中是一個很重要的部分,在項目中會經(jīng)常用到。這篇文章主要帶大家看一下結構體在內(nèi)存中是怎么分布的?通過對內(nèi)存布局的了解,可以幫助我們寫出更優(yōu)質的代碼。感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助
    2022-10-10
  • 一文帶你深入理解Go語言中的sync.Cond

    一文帶你深入理解Go語言中的sync.Cond

    sync.Cond?表示的是條件變量,它是一種同步機制,用來協(xié)調(diào)多個?goroutine?之間的同步。本文將通過示例為大家介紹Go語言中sync.Cond的使用,需要的可以參考一下
    2023-01-01
  • Go?modules?replace解決Go依賴引用問題

    Go?modules?replace解決Go依賴引用問題

    這篇文章主要為大家介紹了Go?modules?replace解決Go依賴引用問題,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • go強制類型轉換type(a)以及范圍引起的數(shù)據(jù)差異

    go強制類型轉換type(a)以及范圍引起的數(shù)據(jù)差異

    這篇文章主要為大家介紹了go強制類型轉換type(a)以及范圍引起的數(shù)據(jù)差異,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10

最新評論