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