我有一个基于导航控制器的应用程序,我遇到了一个奇怪的问题,我的一些视图控制器推送在“弹出”视图控制器时导致崩溃。
我已将其缩小到在将视图控制器推送到导航控制器的堆栈后释放视图控制器的代码行。
我的代码如下所示:
SomeViewController *viewController = [[SomeViewController alloc] init];
[self.navigationController pushViewController:viewController animated:YES];
[viewController release]; //offending line
现在这是正确的内存管理代码,但不幸的是,我收到“双重释放到实例 0x .....”错误(在某些情况下)并且我的应用程序崩溃了。这通常发生在我弹出视图控制器时。
我正在寻找关于看什么的建议。我被困住了。
提前致谢。
编辑:这是下面 Louis 建议的堆栈跟踪转储的结果。
在第一个版本中,保留计数为 13(我猜是由于 CocoaTouch 基类中的一些代码)。最终它归结为:
#2009-08-06 22:33:18.304 My App [26601:20b] ** RELEASE CALLED ** 2009-08-06 22:33:18.306 My App [26601:20b] Retain count was : 1 0 My App 0x000033ec start + 4700 1 CoreFoundation 0x302042e8 CFRelease + 136 2 CoreFoundation 0x30227249 CFNumberGetValue + 2937 3 CoreFoundation 0x30204421 _CFRelease + 241 4 Foundation 0x30506515 NSPopAutoreleasePool + 341 5 QuartzCore 0x00b5436e CA_CGRectUnapplyInverseTransform_ + 19738 6 QuartzCore 0x00b54109 CA_CGRectUnapplyInverseTransform_ + 19125 7 CoreFoundation 0x302454a0 CFRunLoopRunSpecific + 3696 8 CoreFoundation 0x30244628 CFRunLoopRunInMode + 88 9 GraphicsServices 0x32044c31 GSEventRunModal + 217 10 GraphicsServices 0x32044cf6 GSEventRun + 115 11 UIKit 0x309021ee UIApplicationMain + 1157 12 My App 0x00002258 start + 200 13 My App 0x000021c6 start + 54 14 ??? 0x00000001 0x0 + 1 2009-08-06 22:33:18.307 My App [26601:20b] ########### DEALLOC
objc[26601]: FREED(id): message retainCount sent to freed
对象=0xd09070
如果我省略了上面的违规行([viewController release];),那么保留计数只会使其变为 2,并且实例永远不会被释放。