1.首先简单的说一下闭包的概念,写过OC的同学都应该觉得这个和OC中Block很像,但是其中还是有点区别的,OC中的block是匿名的函数而Swift中的闭包是一个特殊的函数,但是两者的共同点都常用于回调。
2.基本的写法在这里简单的说一下(由于笔者能力有限勿喷哦!)
闭包名字 : ((传的参数列表) -> (返回值))? 例如: var requestBack : ((_ jsonData :String) -> ())?
应用场景:多用于网络回调例如:
var callBack : ((_jsonData :String) -> ())?
// 闭包的类型: (参数列表) -> (返回值类型)
funcloadData(callBack :@escaping(_jsonData :String) -> ()) {
// self.callBack = callBack
DispatchQueue.global().async {
print("发送网络请求:\(Thread.current)")
DispatchQueue.main.sync {
callBack("json")
}
}
}
3.重点来了,解决循环引用的方式有三个
@1.写过OC的都知道Block中的解决方式,第一个方式和这个差不多,废话不多说直接干。
/* weakself?.view
如果前面的可选类型,没有值,后面所有的代码都不会执行
如果前面的可选类型,有值,系统会自动将weakself进行解包,并且使用weakself
*/
// 解决循环引用的方式一:
/*
// 0x0 --> nil
weak var weakself = self
tools.loadData { (jsonData) -> () in
// print("在ViewController拿到数据:\(jsonData)")
weakself?.view.backgroundColor = UIColor.redColor()
}
*/
@2.这种方式比较推荐
// 解决循环引用的方式三: 推荐使用该方式
tools.loadData{[weakself] (jsonData) -> ()in
// print("在ViewController拿到数据:\(jsonData)")
self?.view.backgroundColor = UIColor.red
}
@3.这种就不是很常见了
/*
// unowned
tools.loadData {[unowned self] (jsonData) -> () in
// print("在ViewController拿到数据:\(jsonData)")
self.view.backgroundColor = UIColor.redColor()
}
*/
4.简单写的tableview 的Demo(不喜勿喷)
https://github.com/niniios/Swift-nutableview