Golang团队认为在类型系统和运行时的复杂性花费太大,还没找到可以和这个复杂性相抵的良好设计。
内置的map和slice其实都有泛型的味道,加上可以用interface{}来构造容器,可以达到泛型的效果。所以目前为止还没有直接的支持泛型。 (推荐学习:go)
我们这里打算以一些例子来讲解Golang中如何处理这个问题。
首先,我们看一个冒泡排序的问题。针对整型数组切片的排序。
package main import ( "fmt" ) func bubbleSort(array []int) { for i := 0; i < len(array); i++ { for j := 0; j < len(array)-i-1; j++ { if array[j] > array[j+1] { array[j], array[j+1] = array[j+1], array[j] } } } } func main() { a1 := []int{3, 2, 6, 10, 7, 4, 6, 5} bubbleSort(a1) fmt.Println(a1) }
上面的例子输出为:
[2 3 4 5 6 6 7 10]
那么,我们如果希望这个bubbleSort能够同时支持float类型数据排序,或者是按照字符串的长度来排序应该怎么做呢?
在其他的例如java语言中,我们可以将bubbleSort定义为支持泛型的排序,但是Go里面就不行了。为了达到这个目的,我们可以使用interface来实现相同的功能。
针对上面的排序问题,我们可以分析一下排序的步骤:
查看切片长度,以用来遍历元素(Len);
比较切片中的两个元素(Less);
根据比较的结果决定是否交换元素位置(Swap)。
到这里,或许你已经明白了,我们可以把上面的函数分解为一个支持任意类型的接口,任何其他类型的数据只要实现了这个接口,就可以用这个接口中的函数来排序了。
Atas ialah kandungan terperinci golang不支持泛型吗?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!