您的位置 首页 技术

golang不支持泛型吗?

Golang团队认为在类型系统和运行时的复杂性花费太大,还没找到可以和这个复杂性相抵的良好设计。 内置的map和slice其实都有泛型的味道,加上可以用interface{}来构造…

Golang团队认为在类型系统和运行时的复杂性花费太大,还没找到可以和这个复杂性相抵的良好设计。

内置的map和slice其实都有泛型的味道,加上可以用interface{}来构造容器,可以达到泛型的效果。所以目前为止还没有直接的支持泛型。 (推荐学习:go)

我们这里打算以一些例子来讲解Golang中如何处理这个问题。

首先,我们看一个冒泡排序的问题。针对整型数组切片的排序。

package mainimport ("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)。

到这里,或许你已经明白了,我们可以把上面的函数分解为一个支持任意类型的接口,任何其他类型的数据只要实现了这个接口,就可以用这个接口中的函数来排序了。

以上就是golang不支持泛型吗?的详细内容,更多请关注24课堂在线网其它相关文章!

本文来自网络,不代表24小时课堂在线立场,转载请注明出处:https://www.24ketang.cn/17850.html

为您推荐

返回顶部