相比 Objective-C 中的 set 和 get 方法 ,swift 中的set 和 get 要复杂一点。 在swift 中主要分存储型属性 和 计算型属性 这两种 , 一般 我们只是给计算属性添加 get set 重写。
DEMO下载 地址 :https://gitee.com/DeLongYang/iOSFundation 下的 setterAndGetter 工程。
打开 SetterAndGetterTests.swift 文件。进行 单元测试 。我们主要分几个不同的方面来进行测试
1.0
仅仅想获取 原来的值 其实意义不大 OC 中的明显的区别是
swift 中我们 不能使用 _c 来表示 OC 中@property 修饰的变量值 。直接调用
var c:Int{
get{
// 这里 不论是 c 还是 self.c 都会造成 crash 原因是方法的死循环
// 而且 不能像 OC 中 写上 _c
return 1
// return self.c 不论是 c 还是 self.c 都会造成 crash 原因是方法的死循环
// return c 不论是 c 还是 self.c 都会造成 crash 原因是方法的死循环
}
set{
// 我们测试 写上 self.c = newValue 和 不写 都会造成 crash
// 而且 不能像 OC 中 写上 _c
// c = newValue 造成 crash 原因是方法的死循环
a= newValue
print("Recived new value", newValue, " and stored into 'A' ")
}
}
2.0 由于上面提到的原因 重写的时候 我们使用 额外的一个变量来重写
// 使用了 外部的一个变量来重写了这个 方法
var _tittle:String?
var tittle:String?{
set{
_tittle=newValue
}
get{
return_tittle
}
}
3.0 如果只重写 get 方法,默认为 readOnly
var age:Int?{
return20
}
如果对 age 赋值 会造成 IDE 报错
4.0 存储属性: 就是存储一个变量 或 常量 懒加载也属于存储型属性 类似于OC中的方法
let aaa ="aaa"
lazy var ccc:[TestModel] = {
lettestModel =TestModel()
vararr = [TestModel]()
for_in0...99{
arr.append(testModel)
}
//
return arr
}()
5.0 swift 中使用了willset 和 didSet 这连个特性 来见识属性的除初始化之外的 属性值变化
和 OC 比较,我们可以在didSet 里面执行一些改变UI的操作
var newAge:String?{
willSet{
//
print("===========")
}
didSet{
print("did set "+newAge!)
}
}