奇怪的UIAlertView私有方法崩溃_performPopup

时间:2012-11-28 09:56:40

标签: iphone ios xcode uialertview crash-reports

我正试图找出UIAlertView中私有方法导致的崩溃。我的应用程序崩溃中大约有一半涉及此事。

-[UIAlertView(Private) _performPopup:animationType:revealedBySpringBoardAlert:]

这是崩溃报告中的部分。困扰我的是,我的大多数警报视图都是由设计为在整个应用程序生命周期中存在的单例对象弹出的。所以我不确定这是否是由UIAlertView的委托在被它调用之前发布的。谁看过这个吗?你能给些建议么?感谢。

Hardware Model:      iPhone4,1
Version:         ??? (???)
Code Type:       ARM (Native)
Parent Process:  launchd [1]

Date/Time:       2012-11-15 11:31:57.452 -0800
OS Version:      iOS 6.0.1 (10A523)
Report Version:  104

Exception Type:  EXC_BAD_ACCESS (SIGSEGV)
Exception Codes: KERN_INVALID_ADDRESS at 0x5354440a
Crashed Thread:  0

Thread 0 name:  Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0   libobjc.A.dylib                 0x33ab95b6 objc_msgSend + 22
1   UIKit                           0x32e52fa0 -[UIAlertView(Private) _performPopup:animationType:revealedBySpringBoardAlert:]
2   UIKit                           0x330621c4 -[UIAlertView(Private) _repopupNoAnimation]
3   UIKit                           0x33065b38 __36-[_UIAlertStackWatcher _appResumed:]_block_invoke_0
4   libdispatch.dylib               0x37ec211c _dispatch_call_block_and_release
5   libdispatch.dylib               0x37ec14b4 _dispatch_client_callout
6   libdispatch.dylib               0x37ec61b8 _dispatch_main_queue_callback_4CF$VARIANT$mp
7   CoreFoundation                  0x39ba2f36 __CFRunLoopRun
8   CoreFoundation                  0x39b15eb8 CFRunLoopRunSpecific
9   CoreFoundation                  0x39b15d44 CFRunLoopRunInMode
10  GraphicsServices                0x37ee32e6 GSEventRunModal
11  UIKit                           0x32d552f4 UIApplicationMain
12  MYAPP                           0x0000334a main + 70
13  MYAPP                           0x000032fc start + 36

2 个答案:

答案 0 :(得分:3)

这听起来像是代表在这里引起了问题。对于不需要跟踪用户输入的简单UIAlertView,您可以将委托设置为nil,例如:

UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"My Alert" message: @"My Message" delegate: nil cancelButtonTitle:@"OK" otherButtonTitles:nil];
[alert show];

如果您确实需要委托方法,请确保在丢失视图时忽略UIAlertView的委托:

alert.delegate = nil;

在dealloc或者viewWillDisappear中:取决于代码的设置方式!

答案 1 :(得分:0)

当应用程序转到后台时,它也是一个好主意,可以解除警报视图并将其取消。

将以下内容添加到viewDidLoad方法:

 [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(handleApplicationDidEnterBackground:) name:UIApplicationDidEnterBackgroundNotification object:nil];

handleApplicationDidEnterBackground的实现应该如下所示:

- (void)handleApplicationDidEnterBackground:(NSNotification *)n
{
    if (self.alertView)
    {
        self.alertView.delegate = nil;
        [self.alertView dismissWithClickedButtonIndex:[self.alertView cancelButtonIndex] animated:NO];
        self.alertView = nil;
    }
}