泛型对于强类型语言来说是一种便捷开发的方式,只要遵循我的规范,你就可以调用我的方法,科技又一次遵循了工业时代的理念,类似于接口,又高于接口的一种编程方式
在java中泛型已经应用很广泛了,那么在swift中泛型也是那么的给力
//交换两个int数值
var first = 55
var second = 100
func swapIntValues(a: Int, b: Int){
let temp = a
a = b
b = a
}
//调用函数
swapIntValues(&first, &second)
//因为在swift基本类型传递时是按照值传递的,就是赋值一个变量副本传递给函数,函数结束时,并不会影响原先的值,所//以这里利用&来去它的引用,这样first= 100 second = 55
//当需要交换两个字符串时,又要写一个交换字符串的方法,这么不环保的做法,谁能容忍,看泛型走起
func swapValues<T>(a: T, b: T){
let temp = a
a = b
b = temp
}
//这里已经很明确了
//泛型约束,只有泛型可能还不能满足一定的功能,假如在数组中查找是否包含一个,返回这个对象的索引
var data = ["小强","小强250","小强二"]
func findIndex<T>(array: [T], b: T) -> Int?{ //返回类型是一个可选值
for (index,value) in enumerate(array) {
if b == value {
return index
}
}
return nil
}
if let index = findIndex(array: data,b: "小强"){ //可选值可以用作boolean判断
println("\(index)") //输出 0
}
//这是对String的判断用==,然而有时可能要比较两个自定义对象,那么在swift中可以通过一个泛型约束来约束这个类
//实现Equatable ,实现这个协议,可以进行 == 和!=的比较,所有的swift标准类型自动支持Equatable协议
//上面的方法可以变成
func findIndex<T: Equatable>(array: T[],b: T) -> Int?{
for (index,value) in enumerate(array) {
if b == value {
return index
}
}
return nil
}
//类型约束还可以加where条件语句,进一步约束,待续。。。。