Приложение iPhone падает с исключением - PullRequest
0 голосов
/ 04 декабря 2011

У меня есть приложение для iPhone, которое использует iAd ... Приложение иногда вылетает со следующим сообщением;

*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSCFType bannerViewDidLoadAd:]: unrecognized selector sent to instance 0x621cd10'
*** Call stack at first throw:
(
    0   CoreFoundation                      0x00e015a9 __exceptionPreprocess + 185
    1   libobjc.A.dylib                     0x00f55313 objc_exception_throw + 44
    2   CoreFoundation                      0x00e030bb -[NSObject(NSObject) doesNotRecognizeSelector:] + 187
    3   CoreFoundation                      0x00d72966 ___forwarding___ + 966
    4   CoreFoundation                      0x00d72522 _CF_forwarding_prep_0 + 50
    5   CoreFoundation                      0x00d71c7d __invoking___ + 29
    6   CoreFoundation                      0x00d71b51 -[NSInvocation invoke] + 145
    7   CoreFoundation                      0x00d72a04 ___forwarding___ + 1124
    8   CoreFoundation                      0x00d72522 _CF_forwarding_prep_0 + 50
    9   iAd                                 0x00[Switching to process 8860 thread 0x207]
0139f9 -[ADDistributedMessagingCenter messagePort:receivedMessage:withData:] + 251
    10  iAd                                 0x00014012 ADMessagePortCallBack + 75
    11  CoreFoundation                      0x00db8f4c __CFMessagePortPerform + 396
    12  CoreFoundation                      0x00de2944 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 52
    13  CoreFoundation                      0x00d42cf7 __CFRunLoopDoSource1 + 215
    14  CoreFoundation                      0x00d3ff83 __CFRunLoopRun + 979
    15  CoreFoundation                      0x00d3f840 CFRunLoopRunSpecific + 208
    16  CoreFoundation                      0x00d3f761 CFRunLoopRunInMode + 97
    17  GraphicsServices                    0x033fe1c4 GSEventRunModal + 217
    18  GraphicsServices                    0x033fe289 GSEventRun + 115
    19  UIKit                               0x002ffc93 UIApplicationMain + 1160
    20  MyApp                     0x00001ba8 main + 102
    21  MyApp                     0x00001b39 start + 53
)
terminate called after throwing an instance of 'NSException'

Ниже мое сообщение NSZombie;

#   Category    Event Type  RefCt   Timestamp   Address Size    Responsible Library Responsible Caller
77  DetailController    Zombie  -1  04:01.914.883   0x5768bd0   0   iAd -[ADDistributedMessagingCenter messagePort:receivedMessage:withData:]

Также код bannerViewDidLoadAd;

- (void)bannerViewDidLoadAd:(ADBannerView *)banner
{
    if (!bannerIsVisible)
    {
        [UIView beginAnimations:@"animateAdBannerOn" context:NULL];
        // assumes the banner view is offset -50 pixels so that it is not visible.
        banner.frame = CGRectOffset(banner.frame, 0, -50); // if the banner is on top of the screen use 50
        [UIView commitAnimations];
        bannerIsVisible = YES;
    }
}

Пожалуйста, помогите мне исправить то же самое. Спасибо.

Ответы [ 2 ]

1 голос
/ 04 декабря 2011

Обычно вы звоните bannerViewDidLoadAd: с неправильным типом объекта.Похоже, что вы используете какой-то механизм диспетчеризации, чтобы сделать это.Либо вы указали неправильный объект при настройке запроса на отправку для этого метода, либо вам не удалось сохранить объект, и он был удален и заменен объектом NSType.

Так что найдите, где bannerViewDidLoadAd: упоминается вВаш код и убедитесь, что используемый с ним объект является правильным и надлежащим образом сохранен.

0 голосов
/ 11 декабря 2011

bannerViewDidLoad вызывается после освобождения делегата, отсюда и сообщение зомби.

Полагаю, это означает, что ваше объявление не публикуется и застревает после ухода вашего контроллера.

...