0

在我的第一个视图控制器中,我正在做的是从我的 viewDidLoad 中的 UIMangedDocument 设置 NSManagedObjectContext

@property(strong, nonatomic) NSManagedObjectContext *managedObjectContext;

- (void)viewDidLoad
{
     NSURL *filePath = [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject];
     filePath = [filePath URLByAppendingPathComponent:@"Locations"];
     UIManagedDocument *document = [[UIManagedDocument alloc] initWithFileURL:filePath];

    //Create if it doesn't exist
     if (![[NSFileManager defaultManager] fileExistsAtPath:[filePath path]]) {

        //Async save
        [document saveToURL:filePath forSaveOperation:UIDocumentSaveForCreating completionHandler:^(BOOL success) {
             if (success) {
                self.managedObjectContext = document.managedObjectContext;
             }
         }];
    } else if (document.documentState == UIDocumentStateClosed){
        [document openWithCompletionHandler:^(BOOL success){

             //Open it, don't need to refetch stuff
             if (success) {
                self.managedObjectContext = document.managedObjectContext;
             }
         }];
     } else {
         self.managedObjectContext = document.managedObjectContext;
     }
 }

然后我通过我的 NSMangedObject 子类上的类别方法插入一个新对象

[Location createLocationWithName:@"Maui" inManagedObjectContext:self.managedObjectContext];

只是调用此代码

Location *location = [NSEntityDescription insertNewObjectForEntityForName:@"Location" inManagedObjectContext:managedObjectContext];
[managedObjectContext save:nil];

现在我遇到的问题是,当我选择一个具有公共 NSManagedObjectContext 属性的新 ViewController 并将其设置为 prepareForSegue 中的这个 managedObjectContext 时,destinationViewController 中的 NSFetchedResultsController 不会立即接受此更改。在我来回导航几次后,它最终会看到我在上面创建的 Location Maui。为什么将新对象插入 managedObjectContext 然后将其传递给另一个视图控制器的任何想法都不能反映这种变化?

非常感谢任何见解。

4

1 回答 1

0

如果您的创建方法包含名称,您至少还应该设置此属性(否则它将丢失)。所以你的创作实施的第二行:

location.name = name; // name is passed to the method

为了确保第二个视图控制器的获取结果控制器立即更新,您可以在创建 FRC 时设置cacheName为。nil如果您有很多记录并认为需要缓存,则可以在以下位置执行此操作viewWillAppear

[self.fetchedResultsController performFetch:&error];
于 2013-07-26T08:29:04.597 回答