在我正在处理的一个项目中(我选择了这段代码并一直在尝试调试它),我有一个被观察者调用的函数。观察者调用一个方法来更新要放在屏幕上的数据。在发生此更新时(更新需要几秒钟),用户可以按导航栏上的“返回”按钮,这会导致发生 dealloc 调用。当方法运行时,dealloc 调用释放所有 ivars,当方法尝试访问 ivars 时,最终会导致 EXC_BAD_ACCESS。更新方法的结构也包含在 @synchronized
block 中。
- (void)update {
@synchronized(self){
// some code here...
// Also access ivars here.
}
}
如何告诉 Controller 在释放之前先完成方法?我尝试在 dealloc 中运行带有条件的 while 循环,但这似乎效率不高。如果 Controller 被释放,它也永远不会完全执行,并处于死锁状态。我觉得解决方案很简单,但我的大脑因工作一整天而焦头烂额,无法思考。
您可以在 self
上调用 retain
以确保在运行较长时间的方法时引用计数不会达到零;并以这种方式避免 dealloc:
- (void) update {
[self retain]
// do work ...
[self release]
}
关于objective-c - 方法仍在运行时调用了 Dealloc,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11127683/
欢迎光临 OGeek|极客世界-中国程序员成长平台 (https://ogeek.cn/) | Powered by Discuz! X3.4 |