swift 笔记 (十八) —— 扩展
扩展
扩展能够让我们给一个已有的类、结构体、枚举等类型加入�新功能,包含属性和方法,甚至是构造器,下标,支持协议等等。。。
甚至是我们拿不到源码的类、结构体、枚举,我们依旧能够给它加扩展。。。
看到这里的时候,我还有点小激动呢。。。但是淡定下来之后,认为这TMD就是个大大的飞线,飞线,飞线。。。这让我们的代码难以理解全面(总要操心是不是哪里还有扩展,我没读到的。。谁会不会在哪写个飞线出来以达到他不可告人的秘密,所以我们不得不在“代码规范”里写:扩展必须紧挨着类的实现写。但是拿不代码的类呢?我们还要规定必须给文件名称起一个类似xxxxExtensions.swift
或者 xxxxDelegate.swift 这种名字。。。为何不让用户通过代理模式去做这种事情,反而是提供了这样一个反代码反人类的特性。。。)
无论怎么说,既然提供了这种东西,还是记录一下这个奇葩的方式吧。
语法:
extension MyClass {
//要扩展的属性,方法,等功能写在这里
}
extension MyClass: MyProtocol { //协议在后面的笔记里再说,这里仅仅是提一下
//要扩展的属性,方法,等功能写在这里
}
扩展能够做的事儿:
1. 加入�计算型属性和计算型静态属性
2. 定义实例方法和类型方法
3. 提供新的构造器
4. 定义下标
5. 定义和使用新的嵌套类型
6. 使一个已有的类型遵守某个协议
之前在写一个样例的时候,发现 Int没有toString方法,于是,我们借助扩展的强大功能,如今能够让Int有toString方法了:
extension Int {
func toString()->String {
var tmpArray = ["0","1","2","3","4"
,"5","6","7","8","9"]
var tmpNum = self
var tmpString = ""
while tmpNum > 0 {
tmpString = tmpArray[tmpNum % 10] + tmpString
tmpNum /= 10
}
return tmpString
}
}
var myNum:Int = 6234232
println(myNum.toString())
func toString()->String {
var tmpArray = ["0","1","2","3","4"
,"5","6","7","8","9"]
var tmpNum = self
var tmpString = ""
while tmpNum > 0 {
tmpString = tmpArray[tmpNum % 10] + tmpString
tmpNum /= 10
}
return tmpString
}
}
var myNum:Int = 6234232
println(myNum.toString())
注意:这仅仅是个玩具(演示样例),假设用到项目中的话,请考虑更好的写法。
至于文档中提到的构造器,下标,mutating方法,嵌套类型,无非都是这样。。再简单只是,自己写着玩就好了。不列了。