我正在使用NSFetchedResultsController来填充UITableView,其结果来自大约1500个实体的中等大小的Core Data存储。结果控制器是相当标准的 - 潜在错误的一些“热点”不适用于此设置。
然而,我的部分结果非常奇怪。例如,请考虑此方法用于设置节标题视图的标题:
- (NSString *)titleForHeaderInSection:(NSInteger)section {
id <NSFetchedResultsSectionInfo> sectionInfo = [[self.resultsController sections] objectAtIndex:section];
return [sectionInfo name]; // <------- Stopped at breakpoint here
}
我使用断点停在指定的行,并使用GDB检查以下内容:
(gdb) po [[self resultsController] sectionNameKeyPath]
reviewDateString
(gdb) print section
$11 = 1
(gdb) print (int) [sectionInfo numberOfObjects]
$12 = 4
(gdb) po [sectionInfo name]
Wednesday, September 8th 2010
(gdb) po [[[sectionInfo objects] objectAtIndex:0] valueForKey:@"reviewDateString"]
Sunday, February 13th 2011
(gdb) po [[[sectionInfo objects] objectAtIndex:1] valueForKey:@"reviewDateString"]
Sunday, February 13th 2011
(gdb) po [[[sectionInfo objects] objectAtIndex:2] valueForKey:@"reviewDateString"]
Sunday, February 13th 2011
(gdb) po [[[sectionInfo objects] objectAtIndex:3] valueForKey:@"reviewDateString"]
Sunday, February 13th 2011
问题应该是明显的 - 为什么[sectionInfo name]不匹配section中每个托管对象的sectionNameKeyPath的值?该部分中的对象似乎已正确分组,部分名称未正确设置。
如果你看一下,结果就更奇怪了:
(gdb) po [[self resultsController] indexPathForObject:(id)[[sectionInfo objects] objectAtIndex:0]]
<NSIndexPath 0x6615660> 2 indexes [459, 4294966310]
现在很明显,从上面来看,返回的NSIndexPath应该是[1,0],而不是这个伪造的值。
我完全难过了。有人有主意吗?如果您需要更多信息,我会关注这个问题。
[编辑1]
关于我的NSFetchedResultsController设置的一个奇怪的事情是我重新创建(释放并分配/初始化一个新的)结果控制器以响应UISegmentedControl的选择更改。这样做是为了更改获取请求和sectionNameKeyPath的sortDescriptors,以便整体排序发生变化。
[编辑2]
resultsController方法只是我正在使用的NSFetchedResultsController的属性访问器,由@synthesize生成。
段名的预期值已经给出了 - 段名应该等于我在“po [sectionInfo name]”下面显示的@“reviewDateString”键(这是sectionNameKeyPath)的值,所以对于这种情况,他们应该是“2011年2月13日星期日”。
答案 0 :(得分:10)
你可能需要在fetch上修复你的sectionNameKey。
如果此密钥路径与fetchRequest中第一个排序描述符指定的密钥路径不同,则它们必须生成相同的相对排序。例如,fetchRequest中的第一个排序描述符可能指定持久属性的键; sectionNameKeyPath可以指定从持久属性派生的瞬态属性的键。