這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
聽 聽 目前,golang還不支援模板函數(型別參數化),所以看上去不得不為每一種類型都實現一個函數。但是Golang可以利用空介面interface{}和閉包/高階函數來實現泛型函數。
1 空介面
聽 聽 空介面interface{}是指方法集為空白的介面,任何類型的值都可以賦值給空介面。介面相關內容請參見另一篇部落格《Golang中的介面》
//聽interface{}func聽minimum(first聽interface{},聽rest聽...interface{})聽interface{}聽{聽聽聽聽minimum聽:=聽first聽聽聽聽for聽_,聽x聽:=聽range聽rest聽{聽聽聽聽聽聽聽聽switch聽x聽:=聽x.(type)聽{聽聽聽聽聽聽聽聽case聽int:聽聽聽聽聽聽聽聽聽聽聽聽if聽x聽<聽minimum.(int)聽{聽聽聽聽聽聽聽聽聽聽聽聽聽聽聽聽minimum聽=聽x聽聽聽聽聽聽聽聽聽聽聽聽}聽聽聽聽聽聽聽聽case聽float64:聽聽聽聽聽聽聽聽聽聽聽聽if聽x聽<聽minimum.(float64)聽{聽聽聽聽聽聽聽聽聽聽聽聽聽聽聽聽minimum聽=聽float64(x)聽聽聽聽聽聽聽聽聽聽聽聽}聽聽聽聽聽聽聽聽case聽string:聽聽聽聽聽聽聽聽聽聽聽聽if聽x聽<聽minimum.(string)聽{聽聽聽聽聽聽聽聽聽聽聽聽聽聽聽聽minimum聽=聽string(x)聽聽聽聽聽聽聽聽聽聽聽聽}聽聽聽聽聽聽聽聽}聽聽聽聽}聽聽聽聽return聽minimum}func聽main()聽{聽聽聽聽i聽:=聽minimum(4,聽5,聽1,聽9,聽0,聽-1,聽-5,聽7)聽聽聽聽fmt.Println(i)聽聽聽聽j聽:=聽minimum(4.5,聽5.2,聽-0.4,聽9.9,聽2.1)聽聽聽聽fmt.Println(j)聽聽聽聽k聽:=聽minimum("abc",聽"def",聽"xyz",聽"ctz",聽"{}",聽"#$%^&*聽",聽"中國")聽聽聽聽fmt.Println(k)}
運行結果
2 閉包/高階函數
聽 聽 所謂閉包就是一個函數“捕獲”了和它在同一作用於的其他常量和變數,從形式上看匿名函數都是閉包。閉包相關內容請參見另一篇部落格《golang閉包》
//聽closurefuncfilter(limit聽int,聽predicate聽func(int)聽bool,聽appender聽func(int))聽{聽聽聽聽for聽i聽:=聽0;聽i聽<聽limit;聽i++聽{聽聽聽聽聽聽聽聽if聽predicate(i)聽{聽聽聽聽聽聽聽聽聽聽聽聽appender(i)聽聽聽聽聽聽聽聽}聽聽聽聽}}聽聽func聽main()聽{聽聽聽聽a聽:=聽[]int{4,聽-3,聽-8,聽9,聽0,聽2,聽1}聽聽聽聽even聽:=聽[]int{}聽聽聽聽filter(len(a),聽func(i聽int)聽bool聽{聽returna[i]%2聽==聽0聽},聽func(i聽int)聽{聽even聽=聽append(even,聽a[i])聽})聽聽聽聽fmt.Println(even)}
運行結果
聽 聽 上述兩個例子非常巧妙的實現了泛型功能,可見golang“難以置信的靈活和強大”。
聽 聽 不過,至於golang為何不實作類別似C++的模板我還不太理解,在實踐中慢慢感悟吧。
本文出自 “說話的白菜” 部落格,謝絕轉載!