我刚刚重写了这篇文章,涵盖了我能想到的每一个可想到的角度。我不知道为什么会崩溃。也许有人可以帮我搞清楚。
这是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);
我真的不知道问题出在哪里,或者为什么会出现这种问题,但在修复此部分之前,我无法继续使用我的应用程序。
答案 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如何协同工作有点困惑。