首页 > 解决方案 > 关闭如何删除视图控制器的内存?

问题描述

我想了解闭包中的内存管理。

例如,我们有一个视图控制器,它有一个要完成的闭包。当我检查对视图控制器的引用计数时,它显示引用计数 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)
    }

}

标签: iosswift

解决方案


根据Apple Docs ,实例在调用其 deinitializer 之后才会立即释放,一段时间内它的引用计数仍为 1

就在实例释放之前,会自动调用反初始化器。您不能自己调用​​反初始化器。超类反初始化器由其子类继承,超类反初始化器在子类反初始化器实现结束时自动调用。总是调用超类的反初始化器,即使子类不提供自己的反初始化器。

因为一个实例直到调用它的 deinitializer 之后才被释放,所以 deinitializer 可以访问调用它的实例的所有属性,并可以根据这些属性修改其行为(例如查找需要关闭的文件的名称)。


推荐阅读