1

我使用单例来处理数组等。跨应用程序中的视图。

为了初始化单例和NSManagedObjectContext,以便我可以获取对象,我使用:

+(DataControllerSingleton *)singleDataController
{    
    static DataControllerSingleton * single=nil;

    @synchronized(self)
    {
        if(!single)
        {
            single = [[DataControllerSingleton alloc] init];            
            NSManagedObjectContext *context = [single.fetchedResultsController managedObjectContext];

            single.masterCareList = [[NSMutableArray alloc] init];
        }        
    }
    return single;
}

当我插入一个新对象时,该对象不会出现在显示功能中,直到我重新启动应用程序。我通过这个方法在单例类中插入新对象:

- (void)insertNewObject:(Care *)care
{
  NSManagedObjectContext *context = [self.fetchedResultsController managedObjectContext];      

  NSEntityDescription *entity = [[self.fetchedResultsController fetchRequest] entity];

  NSManagedObject *newManagedObject = [NSEntityDescription insertNewObjectForEntityForName:  
   [entity name] inManagedObjectContext:self.managedObjectContext];

  NSString *fileName = care.pictureURL;
  NSString *text = care.causeText;
  NSDate  *date = care.date;
  NSData  *imgData = care.imageData;

  [newManagedObject setValue:fileName forKey:@"urlPath"];
  [newManagedObject setValue:text forKey:@"name"];
  [newManagedObject setValue:date forKey:@"date"];
  [newManagedObject setValue:imgData forKey:@"imageData"];

   // Save the context.
  [self saveContext];

  NSError *error = nil;
  if (![context save:&error]) {
      // 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 %@, %@", error, [error userInfo]);
      abort();
  }
}

我的 count 方法是我可以告诉在我重新启动应用程序之前不包含新对象的方法。count 方法也在单例中。

- (NSUInteger)countOfList
{        
    NSArray *fetchedData = [_fetchedResultsController fetchedObjects];
    return [fetchedData count];   
}

调用单例时,我使用:

DataControllerSingleton *singletonData = [DataControllerSingleton singleDataController];    
[singletonData insertNewObject:care];

managedObjectContext财产:

。H:

@property (readonly, strong, nonatomic) NSManagedObjectContext *managedObjectContext;

米:

@implementation DataControllerSingleton

@synthesize managedObjectContext = _managedObjectContext;
@synthesize managedObjectModel = _managedObjectModel;
@synthesize persistentStoreCoordinator = _persistentStoreCoordinator;

为什么我的新对象在我重新启动应用程序之前不会显示在 ex count 中?

我是否以某种方式使用具有不同上下文的不同线程,或者不同的 fethedResultsController 或不同的单例(不应该是可能的吗?)?


我添加了这两行,它们不包含在生成的 CoreData Stack 中,现在可以正常工作了。

在单例标题中:

@interface DataControllerSingleton : NSObject <NSFetchedResultsControllerDelegate>

在实施文件中,

(NSFetchedResultsController *)fetchedResultsController {

    _fetchedResultsController.delegate = self;
4

1 回答 1

1

我从您的问题中了解到,您正在使用表格或类似的东西。

如果要在保存上下文后立即更新表,则需要:

  1. 重新加载数据表[table reloadData];
  2. 或在正确的委托方法中实现(看看如何使用 NSFetchedResultsController

如果您遵循第一个选项,您可以在上下文中保存并调用表上的 realod 数据。

NSError *error = nil;
if (![context save:&error]) {
  // 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 %@, %@", error, [error userInfo]);
  abort();
}

[table reloadData];

请注意,您调用了两次保存执行一次。在这种情况下,我想像[self saveContext];上面那样进行保存。

如果您采用第二种方法,将为您处理数据重新加载。

希望有帮助。

编辑

您获取的结果控制器的委托应该是一个视图控制器(包含表的那个)。不要把它放在你的单例中!

于 2013-07-03T15:13:07.433 回答