swiftswiftiOS开发技术

解析Swift中闭包的循环引用

2015-11-25  本文已影响7174人  邻家菇凉

1.什么时候会发生循环引用

原理跟OC中的block类似, 当有个属性记录下了函数传递回来的闭包, 产生强引用, 就会发生闭包的循环引用

2.怎么解决循环引用

如何解决闭包的循环引用, 同样有三种方式:

3.如何判断是否发生强引用, 闭包中使用析构函数

//swift dealloc

//析构函数

deinit{

print("销毁")

}
748058-d28cabf10ff73b50.png

4.Swift中的代码

import UIKit

class ViewController: UIViewController {
    var finishedCallBack: ( (dataString: String) -> () )?
    override func viewDidLoad() {
        super.viewDidLoad()

//解决方式三: [unowned self]  跟 _unsafe_unretained 类似  不推荐使用 
        loadData { [unowned self] (dataString) -> () in
            print("\(dataString) \(self.view)")
        }  
    }
    
    func method2() {
        //解决方式二:  在swift中 有特殊的写法 ,跟OC __weak 相似  [weak self]
        loadData { [weak self] (dataString) -> () in
            
            //以后在闭包中中 使用self 都是若引用的
            print("\(dataString) \(self?.view)")
        }
    }
   
    func method1() {
        // 解决方式一: weak
        weak var weakSelf = self
        loadData { (dataString) -> () in
            print("\(dataString) \(weakSelf?.view)")
        }
    }


    func loadData(finished: (dataString: String) -> ()) {
        
        // 记录闭包
        self.finishedCallBack = finished
        //加载数据
        dispatch_async(dispatch_get_global_queue(0, 0)) { () -> Void in
            
            print("执行耗时操作")
            
            dispatch_async(dispatch_get_main_queue(), { () -> Void in
                //执行回调
                self.working()
            })
        }
    }

    
    func working() {
        self.finishedCallBack?(dataString: "<html>")
    }
    
    //swift dealloc
    //析构函数
    deinit {
        print("销毁")
    }
}
上一篇下一篇

猜你喜欢

热点阅读