Golang 中"泛型"的支持
Golang不支持一般的类似java中的标记式泛型。很多人因此而十分不满,认为没有泛型增加了很多工作量。而目前由于泛型支持的复杂性,Golang的设计和实现者并没有把这个泛型支持作为紧急需要增加的特性。但是,如果真的没有泛型,就一定不行了么?答案当然是否定的。没有泛型也可以,而且我觉得代码更简单,直接,有趣(个人观点,勿喷)。 我们这里打算以一些例子来讲解Golang中如何处理这个问题。 首先,我们看一个冒泡排序的问题。针对整型数组切片的排序。 package main import ( "fmt") func bubbleSortarray []int{ for i := 0;< lenarray); i++ j )-i-1 jif array[j]>+],=} func main() a1 {3,31)">2610745 bubbleSorta1 fmt.Println} 上面的例子输出为: [234567] 那么,我们如果希望这个bubbleSort能够同时支持float类型数据排序,或者是按照字符串的长度来排序应该怎么做呢?在其他的例如java语言中,我们可以将bubbleSort定义为支持泛型的排序,但是Go里面就不行了。为了达到这个目的,我们可以使用interface来实现相同的功能。 针对上面的排序问题,我们可以分析一下排序的步骤:
type Sortableinterface LenintLess(boolSwap 下面,我们就用几个例子来描述一下这个接口的用法。typeinterfacearray Sortable();()- //实现接口的整型切片IntArr func IntArrreturni j //实现接口的字符串,按照长度排序StringArrstringStringArr])//测试 intArray1 intArray1 stringArray1 {"hello""i""am""go""lang"stringArray1 输出结果为:1i am go lang hello 上面的例子中,我们首先定义了一个IntArr类型的整型切片类型,然后让这个类型实现了Sortable接口,然后在测试代码中,这个IntArr类型就可以直接调用Sortable接口的bubbleSort方法了。 |