Swift中最常见的内存泄漏陷阱

如果您有内存循环,它将在调试器中向您显示警告:

如果确实有一个(或通常是一堆),则表示您有一个泄漏的物体。

您如何预防呢?

就像在关闭的第一行中添加[unowned self]一样简单!

而已! 它将阻止泄漏。

之所以会发生内存泄漏,是因为Swift中的闭包必须捕获作用域(即{}之间的所有东西)以及您引用的任何self. 它必须保留指向该对象的强大指针,并且即使整个viewController可能已被释放,也永远不会释放它。

[unowned self]是您在Swift闭包中的朋友!

更新:正如中型读者所指出的那样,也可以使用[weak self]代替[unowned self] ,这阻止泄漏 。 但是,Tudor Andrei Marinescu指出了一些重要的考虑因素:

unownedweak之间的区别在于, weak被声明为可选, unowned则不是。 通过声明它是weak您可以处理某些情况下它在闭包内部可能为零的情况。 如果您尝试访问一个恰好为nil的unowned变量,它将使整个程序崩溃。 因此,只有当您肯定变量在闭包周围时将始终存在时,才使用unowned