NSFetchedResultsController(和UITableView)委托方法调用增长和增长

时间:2015-09-08 18:03:01

标签: ios objective-c uitableview core-data nsfetchedresultscontroller

设置:带FRC的UITableView。行是简单的文本内容列表,用户可以通过刷新来获取最新的内容。

我看到奇怪的行为,其中多次为每行调用cellForRow。所以我看到0,0 0,1 0,2 0,3(可见行),但这4行都有多次调用cellForRow。但是第一次查看列表时,它们会被调用一次。第二次,两次,等等。第7次,在用户看到内容之后,在幕后,它继续尝试并反复配置单元并最终崩溃。

因此,如果您访问任何内容列表,它会点击服务器,下载故事,创建NSMO和显示。在日志中,我看到configureCell为每个可见行调用一次。如果我刷新,我看到同样的。但是,如果我导航到另一个屏幕,然后回来,当我拉动刷新时,我注意到每行调用两次cellforrow。如果我继续这个离开和回来的过程,每次我做的时候,cellforrow被称为额外的时间。记录一些获取的结果控制器委托方法,我在每组cellforrow调用之前看到willchangecontent。有人可以帮我确定为什么我的cellforrow方法被称为越来越多次?

一个想法是我设置FRC的方式。我遵循像CoreDataBooks这样的代码并将事情移到了viewdidload,但仍然看到了问题。

我在.h和.m中有一个属性我认为是标准设置:

- (NSFetchedResultsController *)fetchedResultsController
{
//NSLog(@"fetchedresulscontroller");
if (_fetchedResultsController != nil)
{
    return _fetchedResultsController;
}

// initialize fetch request. setup predicate, sort, etc.

NSFetchedResultsController *aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:self.managedObjectContext sectionNameKeyPath:@"date" cacheName:nil];

aFetchedResultsController.delegate = self;
self.fetchedResultsController = aFetchedResultsController;

// perform actual fetch. delegate methods take it from here
NSError *fetchError = nil;
if (![self.fetchedResultsController performFetch:&fetchError])
{
    // Replace this implementation with code to handle the error appropriately.
    // abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
    NSLog(@"Unresolved error %@, %@", fetchError, [fetchError userInfo]);
    abort();
}

return _fetchedResultsController;
}

1 个答案:

答案 0 :(得分:3)

andrewbuilder走在正确的轨道上。这一切都与FRC有关,但诀窍是用于菜单的第三方SWReveal库。事实证明,我每次创建一个新的VC(之前没有取消分配),而FRC正在查看所有实时视图控制器。因此,每次我从菜单中选择一个选项时,都会添加另一个选项并调用配置调用。

解决方案是在viewwilldisappear中取消FRC委托并在viewwillappear中设置它