ios - 关闭如何删除视图控制器的内存?
问题描述
我想了解闭包中的内存管理。
例如,我们有一个视图控制器,它有一个要完成的闭包。当我检查对视图控制器的引用计数时,它显示引用计数 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)
}
}
解决方案
根据Apple Docs ,实例在调用其 deinitializer 之后才会立即释放,一段时间内它的引用计数仍为 1
就在实例释放之前,会自动调用反初始化器。您不能自己调用反初始化器。超类反初始化器由其子类继承,超类反初始化器在子类反初始化器实现结束时自动调用。总是调用超类的反初始化器,即使子类不提供自己的反初始化器。
因为一个实例直到调用它的 deinitializer 之后才被释放,所以 deinitializer 可以访问调用它的实例的所有属性,并可以根据这些属性修改其行为(例如查找需要关闭的文件的名称)。
推荐阅读
- javascript - javascript正则表达式匹配非常具体的搜索(搜索字符串的开头)
- verilog - 灵敏度列表如何在电路级工作?
- javascript - 在对特定字段提出请求时,我在 req.body 上有一个奇怪的行为
- java - 从 clojure 调用带有可选 null 参数的 java 函数
- macos - 以给定路径的特定模式打开 emacs 应用程序
- reactjs - 尝试使用 redux 将值保存到我的商店,但它似乎不起作用
- concurrency - 如何在 fp-ts 中限制并发
- excel - Microsoft.Mashup.OleDb.1 提供程序未在本地计算机上注册
- javascript - 在没有画布的情况下获取按钮单击事件
- amazon-web-services - 通过 IAM Role 从长期运行的 ASP.NET Core 服务访问 AWS 服务