Golang团队认为在类型系统和运行时的复杂性花费太大,还没找到可以和这个复杂性相抵的良好设计。
内置的map和slice其实都有泛型的味道,加上可以用interface{}来构造容器,可以达到泛型的效果。所以目前为止还没有直接的支持泛型。 (推荐学习:go)
我们这里打算以一些例子来讲解Golang中如何处理这个问题。
首先,我们看一个冒泡排序的问题。针对整型数组切片的排序。
立即学习“go语言免费学习笔记(深入)”;
package mainimport ("fmt")func bubbleSort(array []int) {for i := 0; i 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不支持泛型吗?的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3046887.html