Подтвердить что ты не робот

Ошибка iOS 7 или моя ошибка в UIAlertView

У меня есть следующая трассировка стека, в то время как мое приложение падает при нажатии "ОК" на UIAlertView. Это моя ошибка или ошибка iOS7? Я не знаю, как это исправить.

OS Version:          iOS 7.0 (11A465)
Report Version:      104

Exception Type:  EXC_BAD_ACCESS (SIGSEGV)
Exception Subtype: KERN_INVALID_ADDRESS at 0x00000000
Triggered by Thread:  0

Thread 0 name:  Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0   libobjc.A.dylib                 0x39d50b36 objc_msgSend + 22
1   UIKit                           0x3212e3da -[UIAlertView(Private) modalItem:shouldDismissForButtonAtIndex:] + 58
2   UIKit                           0x31ed2036 -[_UIModalItemsCoordinator _notifyDelegateModalItem:tappedButtonAtIndex:] + 90
3   UIKit                           0x31ed1f3e -[_UIModalItemAlertContentView tableView:didSelectRowAtIndexPath:] + 890
4   UIKit                           0x31dd7326 -[UITableView _selectRowAtIndexPath:animated:scrollPosition:notifyDelegate:] + 1074
5   UIKit                           0x31e8a24e -[UITableView _userSelectRowAtPendingSelectionIndexPath:] + 210
6   UIKit                           0x31d3a96e _applyBlockToCFArrayCopiedToStack + 314
7   UIKit                           0x31cb246e _afterCACommitHandler + 426
8   CoreFoundation                  0x2f5141d2 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 18
9   CoreFoundation                  0x2f511b74 __CFRunLoopDoObservers + 280
10  CoreFoundation                  0x2f511eb6 __CFRunLoopRun + 726
11  CoreFoundation                  0x2f47cce2 CFRunLoopRunSpecific + 518
12  CoreFoundation                  0x2f47cac6 CFRunLoopRunInMode + 102
13  GraphicsServices                0x3417727e GSEventRunModal + 134
14  UIKit                           0x31d1ea3c UIApplicationMain + 1132
15  MyApp                           0x000d8e5e 0xcb000 + 56926
16  libdyld.dylib                   0x3a25dab4 start + 0

Код просмотра предупреждений

UIAlertView *av = [[UIAlertView alloc] initWithTitle:@"Error"
    message:[NSString stringWithFormat:@"Es ist ein Fehler aufgetreten: %@", [error localizedDescription]]
    delegate:self
    cancelButtonTitle:@"OK"
    otherButtonTitles:nil];
[av show];

и я не определил метод делегата.

4b9b3361

Ответ 1

Глупо мне, мне просто нужно установить делегат представления предупреждения в nil

Ответ 2

Поскольку делегат UIAlertView является свойством assign в UIAlertView. Я думаю, что это ошибка Apple. Он должен быть слабым указателем в ARC. Но это свойство присваивания, поэтому перед уничтожением делегата вам нужно установить делегат представления предупреждений на nil (большую часть времени, когда класс контроллера выскочил или переместился обратно). Прочитайте файл .h для UIAlertView о делегате, вы можете найти, что это свойство присваивания, и кто-то прокомментировал его после объявления с сообщением "//weak reference".

Ответ 3

Лучший способ избежать проблемы с UIAlertView при использовании делегирования - это введите экземпляр UIAlertView как iVar для класса делегата. И после того, как вы должны сделать свойство delegate alertView равным нулю в dealloc класса делегата

@implementation YOUR_CLASS
{
    UIAlertView *_alert;
}

- (void)dealloc
{
    _alert.delegate = nil;
}


- (void)showAlertView
{
    _alert = [[UIAlertView alloc] initWithTitle:title message:message delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil];
    [alert show];
}

Такой же подход достаточно хорош для всех старых классов с делегатами класса назначения.

Ответ 4

Если вам нужно указать делегата, также будет выполняться "autorelease" в представлении предупреждения.