我有一个应用程序在Snow Leopard服务器上运行了数天和数周。
它使用-[NSRunLoop runUntilDate:]
来“暂停”十秒钟,执行其任务,然后再次暂停。在运行了一个多小时后,我的应用程序崩溃并生成以下报告:
崩溃报告
Exception Type: EXC_BAD_ACCESS (SIGSEGV)
Exception Codes: KERN_INVALID_ADDRESS at 0x0000000000000013
Crashed Thread: 0 Dispatch queue: com.apple.main-thread
Application Specific Information:
objc_msgSend() selector name: release
Thread 0 Crashed: Dispatch queue: com.apple.main-thread
0 libobjc.A.dylib 0x00007fff84cfef0c objc_msgSend + 40
1 com.apple.CoreFoundation 0x00007fff84e363d1 __CFRunLoopDoSources0 + 1361
2 com.apple.CoreFoundation 0x00007fff84e345c9 __CFRunLoopRun + 873
3 com.apple.CoreFoundation 0x00007fff84e33d8f CFRunLoopRunSpecific + 575
4 com.apple.Foundation 0x00007fff83e73b74 -[NSRunLoop(NSRunLoop) runMode:beforeDate:] + 270
5 com.apple.Foundation 0x00007fff83ebf19a -[NSRunLoop(NSRunLoop) runUntilDate:] + 78
乍一看,我以为我的
NSRunLoop
对象不再有效,因此CF内部的release
消息导致崩溃。但是,我认为这并不是问题,因为我在前一行获取了对currentRunLoop
对象的引用。崩溃时间在1到1.5小时之间变化,但我无法确定是什么原因导致的。 如果您有任何评论、意见或调试想法,将不胜感激,因为我不知道下一步该怎么做。
编辑:问题已解决——请参见下面的答案。