来自 UIAlertView _performPopup 的低级 iOS 崩溃
Posted
技术标签:
【中文标题】来自 UIAlertView _performPopup 的低级 iOS 崩溃【英文标题】:low-level iOS crash from UIAlertView _performPopup 【发布时间】:2010-11-30 00:30:47 【问题描述】:我最近遇到了一些低级别的崩溃,尤其是这一次很难确定应用程序的来源/状态。有没有人看到这个或知道这个问题?谢谢!
异常类型:EXC_BAD_ACCESS (SIGSEGV) 异常代码:0x3dcccccd 处的 KERN_INVALID_ADDRESS 崩溃的线程:0
Exception Type: EXC_BAD_ACCESS (SIGSEGV)
Exception Codes: KERN_INVALID_ADDRESS at 0x3dcccccd
Crashed Thread: 0
Thread 0 Crashed:
0 libobjc.A.dylib 0x000025fa objc_msgSend + 18
1 UIKit 0x00162d1c -[UIAlertView(Private) _performPopup:] + 12
2 UIKit 0x001628de -[UIAlertView(Private) _repopup] + 10
3 UIKit 0x0016d196 -[UIAlertView(Private) _removeAlertWindowOrShowAnOldAlert] + 70
4 UIKit 0x00162afa -[UIAlertView(Private) _popoutAnimationDidStop:finished:] + 502
5 UIKit 0x00050ae4 -[UIViewAnimationState sendDelegateAnimationDidStop:finished:] + 184
6 UIKit 0x000509ee -[UIViewAnimationState animationDidStop:finished:] + 34
7 QuartzCore 0x0002ee8c run_animation_callbacks(double, void*) + 284
8 QuartzCore 0x0002ed2c CA::timer_callback(__CFRunLoopTimer*, void*) + 96
9 CoreFoundation 0x00022d1c CFRunLoopRunSpecific + 2092
10 CoreFoundation 0x000224da CFRunLoopRunInMode + 42
11 GraphicsServices 0x000030d4 GSEventRunModal + 108
12 GraphicsServices 0x00003180 GSEventRun + 56
13 UIKit 0x0000342a -[UIApplication _run] + 374
14 UIKit 0x00001954 UIApplicationMain + 636
15 iPadDrinkHub.1.0.7 0x00002f24 0x1000 + 7972
16 iPadDrinkHub.1.0.7 0x00002ed8 0x1000 + 7896
【问题讨论】:
【参考方案1】:奇怪的崩溃有时是内存损坏和/或管理不善的症状。几天前,我刚刚在我的一个应用程序中发现并修复了一个难以发现的错误。该应用程序在 ios 3.2 上已经完美运行了 6 个月,但在 iOS 4.2 上会立即崩溃。在 applicationDidFinishLaunching 期间将主视图添加到窗口时发生崩溃。堆栈跟踪显示 100% iOS 代码;那里没有我的单一功能(applicationDidFinishLaunching 除外)。事实证明,我在加载视图时之前调用的代码中过度释放了 UIImage。 (我错误地在自动发布的 UIImage 上调用 release)。
我还没有看到您所看到的具体崩溃,但您可以尝试以下一些可能会有所启发的方法:
(1) 使用 NSZombieEnabled 运行应用程序。这是您通过 Xcode 设置的环境变量,它通常会识别您可能引用已被释放的对象的位置(例如,就像我之前提到的过度发布示例)。更多细节在这里:
http://www.cocoadev.com/index.pl?NSZombieEnabled
(2) 您可以打开日志记录,以记录发送到所有对象的所有消息。日志写入 tmp 文件夹中的文本文件。如果您检查导致崩溃的日志文件,您可能会对崩溃前发生的事情有所了解。这实际上是我用来解决我的错误的技术。您可以修改代码以启用/禁用日志记录:
instrumentObjcMessageSends(YES);
// Do stuff...
instrumentObjcMessageSends(NO);
或者,您可以直接从调试器调用该函数。例如,在崩溃前设置断点,然后进入调试器控制台并执行以下操作:
(gdb) call (void)instrumentObjcMessageSends(YES)
更多细节在这里:
http://www.dribin.org/dave/blog/archives/2006/04/22/tracing_objc/
【讨论】:
以上是关于来自 UIAlertView _performPopup 的低级 iOS 崩溃的主要内容,如果未能解决你的问题,请参考以下文章