目前,golang还不支持模板函数(类型参数化),因此看上去不得不为每一种类型都实现一个函数。可是Golang能够利用空接口interface{}和闭包/高阶函数来实现泛型函数。golang
1 空接口闭包
空接口interface{}是指方法集为空的接口,任何类型的值均可以赋值给空接口。接口相关内容请参见另外一篇博客《Golang中的接口》
app
// 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) }
运行结果
ide
2 闭包/高阶函数函数
所谓闭包就是一个函数“捕获”了和它在同一做用于的其余常量和变量,从形式上看匿名函数都是闭包。闭包相关内容请参见另外一篇博客《golang闭包》spa
// closure funcfilter(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) }
运行结果rest
上述两个例子很是巧妙的实现了泛型功能,可见golang“难以置信的灵活和强大”。blog
不过,至于golang为什么不实现相似C++的模板我还不太理解,在实践中慢慢感悟吧。接口