ios @try @catch блок EXC_BAD_ACCESS по возвращении из @catch - PullRequest
2 голосов
/ 10 февраля 2012

Этот блок @ try- @ catch в моем viewDidLoad аварийно завершает работу с EXC_BAD_ACCESS при возврате; выполняется в улове, и предупреждение также не показывает:

    @try
    {        
        errorText = @"thumbnails_array";

        unarchiver = [[NSKeyedUnarchiver alloc] initForReadingWithData:data];
        // Customize unarchiver here
        self.thumbnails_array = [unarchiver decodeObjectForKey:@"thumbnails_array"];
        [unarchiver finishDecoding];
        [unarchiver release];


        errorText = @"ThumbNailViewController";

        archivePath = [app.phojoArchiveDir stringByAppendingPathComponent:@"ThumbNailViewController.archive"];
        data = [NSData dataWithContentsOfFile:archivePath];
        unarchiver = [[NSKeyedUnarchiver alloc] initForReadingWithData:data];
        // Customize unarchiver here
        [unarchiver decodeObjectForKey:@"self"];
        [unarchiver finishDecoding];
        [unarchiver release];

        errorText = @"assetsGroupURL";

        archivePath = [app.phojoArchiveDir stringByAppendingPathComponent:@"assetsGroupURL.archive"];
        data = [NSData dataWithContentsOfFile:archivePath];
        unarchiver = [[NSKeyedUnarchiver alloc] initForReadingWithData:data];
        // Customize unarchiver here
        app.assetsGroupURL = [unarchiver decodeObjectForKey:@"assetsGroupURL"];
        [unarchiver finishDecoding];
        [unarchiver release];


    }
    @catch (NSException *exception) 
    {
       UIAlertView * alert = [[UIAlertView alloc] initWithTitle:@"Error" message:@"Phojo is unable to restore the previous editing session." delegate:nil cancelButtonTitle:@"Ok" otherButtonTitles:nil];
        [alert show];
        [alert release];

        NSLog(@"Exception %@ thrown while unarchving %@: Reason: %@ Items in userInfo = %d Stack Trace: %@", [exception name], errorText, [exception reason], [[exception userInfo] count], [NSThread callStackSymbols]);  
        [self.thumbnails_array   release];
        self.thumbnails_array = nil;
        [app.assetsGroupURL release];
        app.assetsGroupURL = nil;

        return;


    }

Этот код запускается в viewDidLoad для извлечения данных, которые были заархивированы во время предыдущего запуска приложения. Я получил исключение в этом коде, заявляющее, что архив непонятен. Но при его сбое приложение вообще не может быть запущено, так как оно запускается и при запуске, и при улове. Есть идеи?

1 Ответ

2 голосов
/ 10 февраля 2012

Ваши assetsGroupURL или thumbnails_array свойства (или оба) объявлены как retain. Это нормально, но это означает, что когда вы вызываете [self.theProperty release] и self.theProperty = nil, вы освобождаете theProperty дважды: второй вызов использует сгенерированный retain сеттер и неявно вызывает release для его текущего значения также. Удалите вызовы release, и вы больше не увидите EXC_BAD_ACCESS.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...