# Go 自定義排序
有的時候我們希望排序不是僅僅按照自然順序排序。例如,我們希望按照字符串的長度來對一個字符串數組排序而不是按照字母順序來排序。這里我們介紹一下Go的自定義排序。
```go
package main
import "sort"
import "fmt"
// 為了能夠使用自定義函數來排序,我們需要一個
// 對應的排序類型,比如這里我們為內置的字符串
// 數組定義了一個別名ByLength
type ByLength []string
// 我們實現了sort接口的Len,Less和Swap方法
// 這樣我們就可以使用sort包的通用方法Sort
// Len和Swap方法的實現在不同的類型之間大致
// 都是相同的,只有Less方法包含了自定義的排序
// 邏輯,這里我們希望以字符串長度升序排序
func (s ByLength) Len() int {
return len(s)
}
func (s ByLength) Swap(i, j int) {
s[i], s[j] = s[j], s[i]
}
func (s ByLength) Less(i, j int) bool {
return len(s[i]) < len(s[j])
}
// 一切就緒之后,我們就可以把需要進行自定義排序
// 的字符串類型fruits轉換為ByLength類型,然后使用
// sort包的Sort方法來排序
func main() {
fruits := []string{"peach", "banana", "kiwi"}
sort.Sort(ByLength(fruits))
fmt.Println(fruits)
}
```
輸出結果
```
[kiwi peach banana]
```
同樣的,對于其他的類型,使用這種方法,我們可以為Go的切片提供任意的排序方法。歸納一下就是:
1. 創建自定義排序類型
2. 實現sort包的接口方法Len,Swap和Less
3. 使用sort.Sort方法來排序
- 版權
- 內容
- Go常量
- Go變量
- Go 數值
- Go 數組
- Go 字典
- Go 函數定義
- Go 方法
- Go 結構體
- Go 閉包函數
- Go 接口
- Go 字符串操作函數
- Go 字符串格式化
- Go 自定義排序
- Go Base64編碼
- Go Defer
- Go Exit.md
- Go for循環
- Go if..else if..else 條件判斷
- Go JSON支持
- Go Line Filters
- Go 狀態協程
- Go Panic
- Go range函數
- Go SHA1 散列
- Go String與Byte切片之間的轉換
- Go Switch語句
- Go URL解析
- Go 遍歷通道
- Go 并行功能
- Go 并行通道Channel
- Go 超時
- Go 錯誤處理
- Go 打點器
- Go 遞歸函數
- Go 讀取文件
- Go 工作池
- Go 關閉通道
- Go 函數多返回值
- Go 函數回調
- Go 函數命名返回值
- Go 互斥
- Go 環境變量
- Go 集合功能
- Go 計時器
- Go 進程觸發
- Go 進程執行
- Go hello world
- Go 可變長參數列表
- Go 命令行參數
- Go 命令行參數標記
- Go 排序
- Go 切片
- Go 請求處理頻率控制
- Go 時間
- Go 時間戳
- Go 時間格式化和解析
- Go 數字解析
- Go 隨機數
- Go 通道的同步功能
- Go 通道方向
- Go 通道緩沖
- Go 通道選擇Select
- Go 寫入文件
- Go 信號處理
- Go 原子計數器
- Go 正則表達式
- Go 指針