无法理解为什么我的GCD桌面视图崩溃了

时间:2012-06-04 15:30:14

标签: iphone ios objective-c uitableview grand-central-dispatch

我刚刚重写了这篇文章,涵盖了我能想到的每一个可想到的角度。我不知道为什么会崩溃。也许有人可以帮我搞清楚。

这是cellForRowAtIndexPath代码:

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString *CellIdentifier = @"Cell";
    JHomeViewCell *cell = (JHomeViewCell *)[tableView dequeueReusableCellWithIdentifier:CellIdentifier];
    if (cell == nil) {
        cell = [[JHomeViewCell alloc] initWithStyle:UITableViewCellStyleDefault
                                    reuseIdentifier:CellIdentifier];
        cell.delegate = self;
    }

    cell.cellContent.cellInfo = [self cellInfoForCellAtIndexPath:indexPath];
    if (cell.cellContent.cellInfo.thumbnailsComplete == YES || cell.cellContent.cellInfo.thumbnailsBeingCreated == YES) {
        [cell.cellContent setNeedsDisplay];
    }
    else {
        [cell.cellContent setup];
    }


    return cell;
}

在cellContent中,有这种设置方法:

-(void)setup {

    [self setNeedsDisplay];

    self.cellInfo.thumbnailsBeingCreated = YES;

    NSManagedObjectID *entryID = self.cellInfo.objectID;

    dispatch_queue_t cellSetupQueue = dispatch_queue_create("com.Journalized.SetupCell", NULL);
    dispatch_async(cellSetupQueue, ^{
        NSManagedObjectContext *newMoc = [[NSManagedObjectContext alloc] init];

        NSPersistentStoreCoordinator *coordinator = [[CoreDataStore mainStore] context].persistentStoreCoordinator;

        [newMoc setPersistentStoreCoordinator:coordinator];
        NSNotificationCenter *notify = [NSNotificationCenter defaultCenter];
        [notify addObserver:self 
                   selector:@selector(mergeChanges:) 
                       name:NSManagedObjectContextDidSaveNotification 
                     object:newMoc];

        Entry *entry = (Entry *)[newMoc objectWithID:entryID];

        [newMoc save:nil];
        int i = 0;

        while (i < self.cellInfo.numberOfThumbnailsToDraw) {
        NSLog(@"number of thumbnails: %i %i %i", self.cellInfo.numberOfThumbnailsToDraw, entry.media.count, i);
            Media *media = [entry.media objectAtIndex:i];
            UIImage *image = [media getThumbnail];

            BOOL success = [newMoc save:nil];

            //NSLog(@"time: %@ success: %i", entry.entryTableInfo.creationTimeString, success);

            [self.cellInfo.thumbnails setObject:image forKey:[NSNumber numberWithInt:i]];
            i++;
        }
        [[NSNotificationCenter defaultCenter] removeObserver:self];

        dispatch_async(dispatch_get_main_queue(), ^{

            self.cellInfo.thumbnailsComplete = YES;

            [self setNeedsDisplay];
        });

    });
    dispatch_release(cellSetupQueue);

它在线上崩溃了:

Media *media = [entry.media objectAtIndex:i];

错误:

index 1 beyond bounds [0 .. 0]

NSLog高于......

NSLog(@"number of thumbnails: %i %i %i", self.cellInfo.numberOfThumbnailsToDraw, entry.media.count, i);

给出结果:

number of thumbnails: 2 1 1

哪种解释崩溃,除了在[cellInfoForCellAtIndexPath:]中设置了值;方法,如:

cellInfo.numberOfMediaItems = entry.media.count;
cellInfo.numberOfThumbnailsToDraw = MIN(cellInfo.numberOfMediaItems, 3);

我真的不知道问题出在哪里,或者为什么会出现这种问题,但在修复此部分之前,我无法继续使用我的应用程序。

3 个答案:

答案 0 :(得分:2)

number numberOfThumbnailsToDraw是2意味着while循环将执行0,1,但是entry.media的计数只有1,因此它只有0索引,所以它当然会崩溃。

答案 1 :(得分:0)

[managedObjectContext obtainPermanentIDsForObjects:self.cellInfo error:nil];
[managedObjectContext save:...];
NSManagedObjectID *entryID = self.cellInfo.objectID;

你需要确保这一点 1.您有永久对象ID;不是临时的 2.该对象被保留,以便它出现在新的MOC上。

答案 2 :(得分:0)

看起来你正在查询entry.media.count,其中entry是指向一个MOC的指针,然后你从另一个MOC查询它。您要求使用objectID,这是合理的。

但是,当新MOC获取对象时,它看不到您在其他MOC中看到的相同值。最有可能的是,这意味着您没有正确保存其他MOC。

如果在新MOC上执行对象的获取,会发生什么?

另外,我将在命令行选项中启用核心数据调试(-com.apple.CoreData.SQLDebug 1)。这将记录到控制台下面发生了什么。您应该看到登录到控制台的基础数据库的SQL语句。

此外,您正在保存您的MOC而不对其进行任何更改,这使我相信您对许多MOC如何协同工作有点困惑。