SWIFT中最常见的内存泄漏陷阱
如果您有内存循环,它将在调试器中向您显示警告:
如果确实有一个(或通常是一堆),则表示您有一个泄漏的物体。
您如何预防呢?
就像在关闭的第一行中添加[unowned self]一样简单!
而已! 它将阻止泄漏。
之所以会发生内存泄漏,是因为Swift中的闭包必须捕获作用域(即{}之间的所有东西)以及您引用的任何self. 它必须保留指向该对象的强大指针,并且即使整个viewController可能已被释放,也永远不会释放它。
[unowned self]是您在Swift闭包中的朋友!
更新:正如中型读者所指出的那样,也可以使用[weak self]代替[unowned self] ,这也将阻止泄漏 。 但是,Tudor Andrei Marinescu指出了一些重要的考虑因素:
unowned和weak之间的区别在于,weak被声明为可选,unowned则不是。 通过声明它是weak您可以处理某些情况下它在闭包内部可能为零的情况。 如果您尝试访问一个恰好为nil的unowned变量,它将使整个程序崩溃。 因此,只有当您肯定变量在闭包周围时将始终存在时,才使用unowned