Swift 中的闭包

2018-10-17  本文已影响0人  Fultom

在iOS开发中Swift开源后,Swift凭借着其代码的简洁被广大猿友们喜欢,Swift也越来越完善,所有学习他也是势在必行的.
今天我就分享一个我在学习过程中遇到的一个坑,希望能帮助小伙伴们更好的学习
在oc中block是常用的方法,有人评价block函数十步杀一人,千里不流行,显而易见block的强大,如果没有block,就会出现一个类需要使用其他类时,要遵循十几个delegate,几十个delegate方法的情况.逻辑到处散落,难以理清.

======以上都是废话=======

在Swift 中没有block,但是有着闭包代替。
在oc中我们我们为了防止循环引用不被释放在block块中调用self 的时候用__weak来修饰 __weak typeof(self) weakSelf = self; 而在Swift中是这样的 weak var weakSelf = self
但是当我定义了一个闭包:

    {
        print("我是loadData方法中的代码");
        self.finished = finished;
        finished()
    }
在viewDidLoad调用这个闭包
override func viewDidLoad() {
        super.viewDidLoad()

        weak var weakSelf = self
        loadData { 
            print("回到主线程")
            
            //在Swift中能不写self就不写self..但是在闭包中必须写上self
            
            weakSelf.view.backgroundColor = UIColor.redColor();
        } 
image.png

那么调用直接标红线了,他提示写上一个!,后来我才知道这个原因
在Swift中,如果在某个类中定义一个属性,那么这个属性必须要被初始化,否则就会报错。


image.png

如果暂时不想初始化,那么可以在后面写上一个?号
在这个里要加!号也是因为这个原因,意思就是告诉编译器我这个weakSelf是有值的

// var finished:()->()?
/* 注意: 这个是错误的写法,当前写法代表闭包的返回值可以使nil */
var finished:(()->())?

上一篇 下一篇

猜你喜欢

热点阅读