在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 教程/ GO/ ?# 11.7 第一個例子:使用 Sorter 接口排序
4.7 strings 和 strconv 包
13.6 啟動外部命令和程序
?# 11.4 類型判斷:type-switch
12.1 讀取用戶的輸入
10.6 方法
12.2 文件讀寫
13 錯誤處理與測試
9.3 鎖和 sync 包
12.3 文件拷貝
?# 11.7 第一個例子:使用 Sorter 接口排序
?# 11.5 測試一個值是否實現(xiàn)了某個接口
6.4 defer 和追蹤
12.10 XML 數(shù)據(jù)格式
13.10 性能調(diào)試:分析并優(yōu)化 Go 程序
?# 11.1 接口是什么
2.2 Go 環(huán)境變量
2.6 安裝目錄清單
2.5 在 Windows 上安裝 Go
11.11 Printf 和反射
1.2 語言的主要特性與發(fā)展的環(huán)境和影響因素
9.0 包(package)
7.4 切片重組(reslice)
13.2 運行時異常和 panic
10.2 使用工廠方法創(chuàng)建結(jié)構(gòu)體實例
12.8 使用接口的實際例子:fmt.Fprintf
2.4 在 Mac OS X 上安裝 Go
3.8 Go 性能說明
7.2 切片
8.0 Map
3.1 Go 開發(fā)環(huán)境的基本要求
5.6 標簽與 goto
6.10 使用閉包調(diào)試
9.5 自定義包和可見性
4.3 常量
?# 11.2 接口嵌套接口
6.5 內(nèi)置函數(shù)
前言
10.8 垃圾回收和 SetFinalizer
2.8 Go 解釋器
13.7 Go 中的單元測試和基準測試
6.8 閉包
4.9 指針
13.1 錯誤處理
10.1 結(jié)構(gòu)體定義
5.1 if-else 結(jié)構(gòu)
6.6 遞歸函數(shù)
9.9 通過 Git 打包和安裝
2.7 Go 運行時(runtime)
10.7 類型的 String() 方法和格式化描述符
3.7 其它工具
9.6 為自定義包使用 godoc
11.12 接口與動態(tài)類型
13.3 從 panic 中恢復(fù)(Recover)
10.3 使用自定義包中的結(jié)構(gòu)體
11.14 結(jié)構(gòu)體、集合和高階函數(shù)
3.6 生成代碼文檔
9.2 regexp 包
4.1 文件名、關(guān)鍵字與標識符
?# 11.6 使用方法集與接口
7.0 數(shù)組與切片
7.1 聲明和初始化
12.11 用 Gob 傳輸數(shù)據(jù)
5.5 Break 與 continue
1.1 起源與發(fā)展
?# 11 接口(Interfaces)與反射(reflection)
6.9 應(yīng)用閉包:將函數(shù)作為返回值
4.2 Go 程序的基本結(jié)構(gòu)和要素
8.6 將 map 的鍵值對調(diào)
6.11 計算函數(shù)執(zhí)行時間
5.0 控制結(jié)構(gòu)
10.5 匿名字段和內(nèi)嵌結(jié)構(gòu)體
4.6 字符串
3.0 編輯器、集成開發(fā)環(huán)境與其它工具
13.8 測試的具體例子
7.6 字符串、數(shù)組和切片的應(yīng)用
8.4 map 類型的切片
3.9 與其它語言進行交互
7.3 For-range 結(jié)構(gòu)
9.7 使用 go install 安裝自定義包
6.0 函數(shù)
9.8 自定義包的目錄結(jié)構(gòu)、go install 和 go test
6.3 傳遞變長參數(shù)
13.9 用(測試數(shù)據(jù))表驅(qū)動測試
11.9 空接口
8.1 聲明、初始化和 make
6.2 函數(shù)參數(shù)與返回值
9.11 在 Go 程序中使用外部庫
3.3 調(diào)試器
4.5 基本類型和運算符
?# 11.8 第二個例子:讀和寫
12.5 用 buffer 讀取文件
總結(jié):Go 中的面向?qū)ο?/span>
11.10 反射包
12.7 用 defer 關(guān)閉文件
9.4 精密計算和 big 包
4.4 變量
6.1 介紹
13.4 自定義包中的錯誤處理和 panicking
12.4 從命令行讀取參數(shù)
9.10 Go 的外部包和項目
8.3 for-range 的配套用法
3.5 格式化代碼
10.4 帶標簽的結(jié)構(gòu)體
7.5 切片的復(fù)制與追加
?# 11.3 類型斷言:如何檢測和轉(zhuǎn)換接口變量的類型
5.4 for 結(jié)構(gòu)
4.8 時間和日期
2.3 在 Linux 上安裝 Go
12 讀寫數(shù)據(jù)
6.12 通過內(nèi)存緩存來提升性能
9.1 標準庫概述
12.6 用切片讀寫文件
10 結(jié)構(gòu)(struct)與方法(method)
8.5 map 的排序
12.9 JSON 數(shù)據(jù)格式
13.5 一種用閉包處理錯誤的模式
3.2 編輯器和集成開發(fā)環(huán)境
12.12 Go 中的密碼學(xué)
5.2 測試多返回值函數(shù)的錯誤
6.7 將函數(shù)作為參數(shù)
8.2 測試鍵值對是否存在及刪除元素
3.4 構(gòu)建并運行 Go 程序
2.1 平臺與架構(gòu)
5.3 switch 結(jié)構(gòu)

?# 11.7 第一個例子:使用 Sorter 接口排序

?# 11.7 第一個例子:使用 Sorter 接口排序

一個很好的例子是來自標準庫的 sort 包,要對一組數(shù)字或字符串排序,只需要實現(xiàn)三個方法:反映元素個數(shù)的 Len()方法、比較第 ij 個元素的 Less(i, j) 方法以及交換第 ij 個元素的 Swap(i, j) 方法。

排序函數(shù)的算法只會使用到這三個方法(可以使用任何排序算法來實現(xiàn),此處我們使用冒泡排序):

func Sort(data Sorter) {
    for pass := 1; pass < data.Len(); pass++ {
        for i := 0;i < data.Len() - pass; i++ {
            if data.Less(i+1, i) {
                data.Swap(i, i + 1)
            }
        }
    }
}

Sort 函數(shù)接收一個接口類型的參數(shù):Sorter ,它聲明了這些方法:

type Sorter interface {
    Len() int
    Less(i, j int) bool
    Swap(i, j int)
}

參數(shù)中的 int 是待排序序列長度的類型,而不是說要排序的對象一定要是一組 int。ij 表示元素的整型索引,長度也是整型的。

現(xiàn)在如果我們想對一個 int 數(shù)組進行排序,所有必須做的事情就是:為數(shù)組定一個類型并在它上面實現(xiàn) Sorter 接口的方法:

type IntArray []int
func (p IntArray) Len() int           { return len(p) }
func (p IntArray) Less(i, j int) bool { return p[i] < p[j] }
func (p IntArray) Swap(i, j int)      { p[i], p[j] = p[j], p[i] }

下面是調(diào)用排序函數(shù)的一個具體例子:

data := []int{74, 59, 238, -784, 9845, 959, 905, 0, 0, 42, 7586, -5467984, 7586}
a := sort.IntArray(data) //conversion to type IntArray from package sort
sort.Sort(a)

完整的、可運行的代碼可以在 sort.gosortmain.go 里找到。

同樣的原理,排序函數(shù)可以用于一個浮點型數(shù)組,一個字符串?dāng)?shù)組,或者一個表示每周各天的結(jié)構(gòu)體 dayArray

示例 11.6 sort.go

package sort

type Sorter interface {
    Len() int
    Less(i, j int) bool
    Swap(i, j int)
}

func Sort(data Sorter) {
    for pass := 1; pass < data.Len(); pass++ {
        for i := 0; i < data.Len()-pass; i++ {
            if data.Less(i+1, i) {
                data.Swap(i, i+1)
            }
        }
    }
}

func IsSorted(data Sorter) bool {
    n := data.Len()
    for i := n - 1; i > 0; i-- {
        if data.Less(i, i-1) {
            return false
        }
    }
    return true
}

// Convenience types for common cases
type IntArray []int

func (p IntArray) Len() int           { return len(p) }
func (p IntArray) Less(i, j int) bool { return p[i] < p[j] }
func (p IntArray) Swap(i, j int)      { p[i], p[j] = p[j], p[i] }

type StringArray []string

func (p StringArray) Len() int           { return len(p) }
func (p StringArray) Less(i, j int) bool { return p[i] < p[j] }
func (p StringArray) Swap(i, j int)      { p[i], p[j] = p[j], p[i] }

// Convenience wrappers for common cases
func SortInts(a []int)       { Sort(IntArray(a)) }
func SortStrings(a []string) { Sort(StringArray(a)) }

func IntsAreSorted(a []int) bool       { return IsSorted(IntArray(a)) }
func StringsAreSorted(a []string) bool { return IsSorted(StringArray(a)) }

示例 11.7 sortmain.go

package main

import (
    "./sort"
    "fmt"
)

func ints() {
    data := []int{74, 59, 238, -784, 9845, 959, 905, 0, 0, 42, 7586, -5467984, 7586}
    a := sort.IntArray(data) //conversion to type IntArray
    sort.Sort(a)
    if !sort.IsSorted(a) {
        panic("fails")
    }
    fmt.Printf("The sorted array is: %v\n", a)
}

func strings() {
    data := []string{"monday", "friday", "tuesday", "wednesday", "sunday", "thursday", "", "saturday"}
    a := sort.StringArray(data)
    sort.Sort(a)
    if !sort.IsSorted(a) {
        panic("fail")
    }
    fmt.Printf("The sorted array is: %v\n", a)
}

type day struct {
    num       int
    shortName string
    longName  string
}

type dayArray struct {
    data []*day
}

func (p *dayArray) Len() int           { return len(p.data) }
func (p *dayArray) Less(i, j int) bool { return p.data[i].num < p.data[j].num }
func (p *dayArray) Swap(i, j int)      { p.data[i], p.data[j] = p.data[j], p.data[i] }

func days() {
    Sunday    := day{0, "SUN", "Sunday"}
    Monday    := day{1, "MON", "Monday"}
    Tuesday   := day{2, "TUE", "Tuesday"}
    Wednesday := day{3, "WED", "Wednesday"}
    Thursday  := day{4, "THU", "Thursday"}
    Friday    := day{5, "FRI", "Friday"}
    Saturday  := day{6, "SAT", "Saturday"}
    data := []*day{&Tuesday, &Thursday, &Wednesday, &Sunday, &Monday, &Friday, &Saturday}
    a := dayArray{data}
    sort.Sort(&a)
    if !sort.IsSorted(&a) {
        panic("fail")
    }
    for _, d := range data {
        fmt.Printf("%s ", d.longName)
    }
    fmt.Printf("\n")
}

func main() {
    ints()
    strings()
    days()
}

輸出:

The sorted array is: [-5467984 -784 0 0 42 59 74 238 905 959 7586 7586 9845]
The sorted array is: [ friday monday saturday sunday thursday tuesday wednesday]
Sunday Monday Tuesday Wednesday Thursday Friday Saturday 

備注

panic("fail") 用于停止處于在非正常情況下的程序(詳細請參考 第13章),當(dāng)然也可以先打印一條信息,然后調(diào)用 os.Exit(1) 來停止程序。

上面的例子幫助我們進一步了解了接口的意義和使用方式。對于基本類型的排序,標準庫已經(jīng)提供了相關(guān)的排序函數(shù),所以不需要我們再重復(fù)造輪子了。對于一般性的排序,sort 包定義了一個接口:

type Interface interface {
    Len() int
    Less(i, j int) bool
    Swap(i, j int)
}

這個接口總結(jié)了需要用于排序的抽象方法,函數(shù) Sort(data Interface) 用來對此類對象進行排序,可以用它們來實現(xiàn)對其他類型的數(shù)據(jù)(非基本類型)進行排序。在上面的例子中,我們也是這么做的,不僅可以對 intstring 序列進行排序,也可以對用戶自定義類型 dayArray 進行排序。

練習(xí) 11.5 interfaces_ext.go:

a). 繼續(xù)擴展程序,定義類型 Triangle,讓它實現(xiàn) AreaInterface 接口。通過計算一個特定三角形的面積來進行測試(三角形面積=0.5 (底 高))

b). 定義一個新接口 PeriInterface,它有一個 Perimeter 方法。讓 Square 實現(xiàn)這個接口,并通過一個 Square 示例來測試它。

練習(xí) 11.6 point_interfaces.go:

繼續(xù) 10.3 中的練習(xí) point_methods.go,定義接口 Magnitude,它有一個方法 Abs()。讓 Point、Point3Polar 實現(xiàn)此接口。通過接口類型變量使用方法做point.go中同樣的事情。

練習(xí) 11.7 float_sort.go / float_sortmain.go:

類似11.7和示例11.3/4,定義一個包 float64,并在包里定義類型 Float64Array,然后讓它實現(xiàn) Sorter 接口用來對 float64 數(shù)組進行排序。

另外提供如下方法:

  • NewFloat64Array():創(chuàng)建一個包含25個元素的數(shù)組變量(參考10.2)
  • List():返回數(shù)組格式化后的字符串,并在 String() 方法中調(diào)用它,這樣就不用顯式地調(diào)用 List() 來打印數(shù)組(參考10.7)
  • Fill():創(chuàng)建一個包含10個隨機浮點數(shù)的數(shù)組(參考4.5.2.6)

在主程序中新建一個此類型的變量,然后對它排序并進行測試。

練習(xí) 11.8 sort.go/sort_persons.go:

定義一個結(jié)構(gòu)體 Person,它有兩個字段:firstNamelastName,為 []Person 定義類型 Persons 。讓 Persons 實現(xiàn) Sorter 接口并進行測試。

鏈接