关闭如何删除视图控制器的内存?
Posted
技术标签:
【中文标题】关闭如何删除视图控制器的内存?【英文标题】:How the closure remove the memory for view controller? 【发布时间】:2020-01-28 04:29:46 【问题描述】:我想了解闭包中的内存管理。
例如,我们有一个视图控制器,它需要完成一个闭包。当我检查对视图控制器的引用计数时,它显示引用计数 1。
什么时候会清除/移除已关闭视图控制器的内存?
这是我的代码。
class ViewController: UIViewController
@IBOutlet weak var buttonToHide: UIButton!
override func viewDidLoad()
super.viewDidLoad()
// Do any additional setup after loading the view.
@IBAction func showSecondViewController()
guard let second = self.storyboard?.instantiateViewController(withIdentifier: "second") else return
present(second, animated: true, completion: nil)
class SecondViewControler: UIViewController
@IBOutlet weak var lbl: UILabel!
override func viewDidLoad()
super.viewDidLoad()
override func viewDidAppear(_ animated: Bool)
super.viewDidAppear(animated)
deinit
print("\(self) is being deinitialized") // still self object is there
print(_getRetainCount(self)) // returning 1
@IBAction func dismissController()
DispatchQueue.main.asyncAfter(deadline: .now() + .seconds(6))
self.lbl.text = "HHi"
print("self reference : ",self.lbl.description)
self.dismiss(animated: true, completion: nil)
override func viewDidDisappear(_ animated: Bool)
super.viewDidAppear(animated)
print("viewDidDisappear", self.lbl.description)
【问题讨论】:
请参考下面的闭包的强参考循环,你会很清楚它是如何工作的。 docs.swift.org/swift-book/LanguageGuide/… 我认为除非deinit
方法完成,否则引用计数将为 1。所以在完全关闭后检查引用计数。
【参考方案1】:
根据Apple Docs,实例不会立即被释放,直到调用它的 deinitializer 之后它仍然有一段时间的引用计数 1
在实例之前自动调用反初始化器 释放发生。不允许调用反初始化器 你自己。超类反初始化器由其子类继承, 并且超类反初始化器在结束时自动调用 子类反初始化器实现。超类反初始化器是 总是被调用,即使子类不提供自己的 去初始化器。
因为一个实例直到它的 deinitializer 之后才被释放 被调用时,反初始化器可以访问实例的所有属性 它被调用并可以根据这些属性修改其行为 (比如查找需要关闭的文件名)。
【讨论】:
以上是关于关闭如何删除视图控制器的内存?的主要内容,如果未能解决你的问题,请参考以下文章