来自 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 崩溃的主要内容,如果未能解决你的问题,请参考以下文章

UIAlertView 更新标题

UIAlertView 的私有方法崩溃

如何从 appDelegate 呈现 UIAlertView

从当前模态的委托中呈现 UIAlertView

快速显示 UIAlertView 时出错

为啥我的所有 UIAlertView 标签/文本在 iOS 8 中默认为粗体