最近公司的又一个app音LIVE也成功上线,总算也些时间来看看自己想了解的东西,Swift也出了出了这么久,以前也只是简单看了下语法,并没有机会用到公司项目中,不知不觉早已经忘了,今天打算温习下Swift,可能会模仿一些其它App来练练手。后面会慢慢记录模仿的过程吧。也当是写的简单笔记,方便以后回来翻阅。
1.闭包可能引起的循环引用及解决办法
学习过swift语法的都知道闭包和OC中的block很相似,如果不知道请自行百度吧。
首先为了模拟循环引用的场景,比如导航控制器A push到B ,我们从B 中返回A,这样B就会被销毁。可是swift中怎么知道它被销毁了呢,在OC中可以重写dealloc方法,它被调用就证明被销毁了,然后swift中并没有这个方法,但是有另外方法deinit是在销毁的时候调用。
首先我们在B 控制器中定义一个方法,方法中传一个闭包参数,定义如下
func loadNewData(finish:()->()) {
print("我要加载数据,这个操作很耗时")
// 加载完数据我回到主线程更新UI
finish()
}
然后我们在B控制器中的viewDidLoad中调用,调用如下
//调用
loadNewData {
print("我在这里更新UI")
}
改写deinit方法
deinit {
print("我被销毁了")
}
这个时候我push 到B然后返回会调用deinit方法,因为我们这里并没有出现循环引用。
最后我们在B中定义一个闭包属性如下
var finish:(()->())?
改下loadNewData方法
func loadNewData(finish:()->()) {
print("我要加载数据,这个操作很耗时")
// 加载完数据我回到主线程更新UI
self.finish = finish
finish()
}
调用也改下
//调用
loadNewData {
print("我在这里更新UI")
self.view.backgroundColor = UIColor.redColor()
}
这个时候我们再push,然后返回发现deinit方法不在调用。说明这里出现了循环引用。
解决办法如下
//调用
weak var weakSelf = self
loadNewData {
print("我在这里更新UI")
weakSelf!.view.backgroundColor = UIColor.redColor()
}
二.如何重写setter和getter方法?
class Student: NSObject {
var _name:String?
var name:String? {
get {
return _name
}
set {
_name = newValue
}
}
}
不得不吐槽下这个写法,真心蛋痛。
如果我们需要在setter方法中需要做一些操作,一般用下面的写法
var age:Int? {
// 设置值完以后调用,在swift中通过改写改方法来代替改写setter方法
didSet {
print("\(age)")
}
}
注意:如果我们只重写getter方法的话,就只相当于OC中readonly属性一样
var gender:String? {
// 如果只重写get方法,那么这个属性称之计算型数学,相当于oc中只读属性,不占用内存
get {
return "1"
}
}
三.如何使用KVC
在swift中定义字典转模型方法,必须要调用super.init才可以,还有就是对象类型的属性可以是可选类型,但是如果是基本数据类型的属性如Int必须初始化,要不然会崩溃报错。
我开始定义两个属性,一个对象属性,一个为基本数据属性,如下
var name:String?
var age :Int?
字典转模型的方法
init (dict: [String : AnyObject]) {
//在swift中使用kvo需要调用
super.init()
setValuesForKeysWithDictionary(dict)
}
运行时会崩溃报错。。。
后面把age属性改为如下就可以了,
var name:String?
var age: Int = 0
四.怎么写懒加载?
在OC中懒加载几乎无处不在的赶脚,那swift怎么写呢?有一个lazy关键字,写法如下
lazy var dataList:[String] = {
return ["1","2","3"]
}()
注意大括号后面的小括号不能少!!!
结尾
上面这些是我从OC过来Swift遇到的一些坑的记录,如果有什么错误望指正,谢谢,该睡了。