核心数据:手动故障管理对象后未释放内存

时间:2013-08-23 04:58:51

标签: ios objective-c core-data memory-management automatic-ref-counting

我使用以下代码检索Core Data上属性的最大值

- (NSDate*)latestDateForLocalEntity:(NSString*)entityString
   key:(NSString*)key 
   inManagedObjectContext:(NSManagedObjectContext*)context {

   NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:entityString];
   NSSortDescriptor *sortDescriptor = [NSSortDescriptor sortDescriptorWithKey:key ascending:YES];
   request.sortDescriptors = @[sortDescriptor];
   NSError *localError;
   NSArray *localResults = [context executeFetchRequest:request error:&localError];
   id result = localResults.lastObject;

   NSDate *latestLocalDate = [result valueForKey:key];
   NSLog(@"Latest local date for entity %@ (%@): %@",entityString,key,latestLocalDate);

   // fault newly created objects - don`t need to keep them in RAM:
   [localResults enumerateObjectsUsingBlock:^(NSManagedObject *managedObject, NSUInteger idx, BOOL *stop) {
      [context refreshObject:managedObject mergeChanges:NO];
   }];

   // even context reset does not help reducing RAM consumption:

  [context reset];
  localResults = nil;
  return latestLocalDate;

代码检索所有实体,按值对它们进行排序,并使最后一个对象获得最大值。然后它尝试(重新)对值进行故障以释放RAM:[context refreshObject:managedObject mergeChanges:NO]

但是,内存似乎没有被释放(大约有400.000 non-object个对象被保存在内存中。

我的代码尝试修改对象并重置托管对象上下文有什么问题? 为什么不释放内存?

1 个答案:

答案 0 :(得分:1)

如果您只对一个属性的最大值感兴趣,我建议您只使用

获取一个对象
// Sort descending to that the first object is that with the maximum value.
NSSortDescriptor *sortDescriptor = [NSSortDescriptor sortDescriptorWithKey:key ascending:NO];
[request setSortDescriptors:@[sortDescriptor]];
[request setFetchLimit:1];

然后只有一个对象被加载到内存中,而不是该实体的所有对象。

此外,您只能获取您感兴趣的属性 而不是托管对象:

[request setResultType:NSDictionaryResultType];
[request setPropertiesToFetch:@[key]];

然后结果是一个字典数组,并且没有加载任何托管对象 完全进入上下文。这里需要注意的是,结果反映了持久性存储中的当前状态,并没有考虑上下文中任何挂起的更改,插入或删除。