为何使用泛型
- 在编程语言中,往往有很多的数据类型,如果我们需要对每个类型都进行相同的操作,那么就需要为每种类型都编写一段相同的代码,比如我们想要比较两个值得大小.一般会写成这样
- func maxInt(a:Int,b:Int) ->Int{
- return a>b?a:b
- }
基本的使用
- func maxAny<T>(a:T,b:T) ->T{
- return a>b?a:b
- }
这里的
T
是一个类型占位符,由于没有为T
设定协议,所以它表示任意类型.让函数的两个参数都是T
类型,这样函数就可以接受任何类型了.但是这行代码会出现一个错误:
Binary operator '>' cannot be applied to two 'T' operands
为啥呢? 因为>
比较符只能作用于符合Comparable
协议的类型,而任意类型的T
不符合任何协议.这里先不管,我们使用输出语句试试这个方法是否真的能接受任何数据类型
那么如何让
a
和b
可以比较呢?只要为T
添加Comparable
协议即可
- func maxAny<T:Comparable>(a:T,b:T) ->T{
- return a>b?a:b
- }
这样就表示,只有符合
Comparable
协议的类型才可以作为方法的参数传递进来.Comparable
协议是专门用来比较的协议,不支持比较的类型不会添加这个协议,比如String
类型.
这里就完成了,只要一个方法,就可以传递多种类型的参数,这个就是使用泛型的主要目的
常见的泛型使用
- swift中,Array是可以接受任何类型的.但是我们可以使用泛型,让Array只接受一种数据类型.
- var array:Array<Int> = Array()//声明一个数组
- array.append(10)//将整数加入数组
- array.append("str")//将String加入数组
这时就会发现,第三行代码报错了,
Cannot convert value of type 'String' to expected argument type 'Int'
就是说String
类型无法转换成预期中得Int
类型,这说明数组就只能存放Int
类型的了.这样有什么好处呢?这样我们可以很方便的清楚数组中得类型,使用起来更安全.除了数组,字典也同样支持泛型.
在类中使用泛型
- 模拟一个类似于Array的类
- class Test<T> {
- var items = [T]()
- func append(item:T){
- items.append(item)
- }
- } //接下来是使用
- var a:Test<Int> = Test()
- a.append(12)
- a.append("asd") //这里第三行同样会报错,和Array类型是一样的
这样做的好处就是这个类本身可以接收任意的类型,也可以指定类接收的类型.