У меня случайные сбои с основными данными из-за concurrency и многопоточности. Я знаю, что основные данные не являются потокобезопасными. Я также нашел пару других ответов о том, как создать ThreadedDataService и создать отдельный контекст для каждого потока.
Это слишком много для меня, чтобы усвоить на данный момент, поэтому я пытаюсь найти более простой выход.
Решение, которое я пытаюсь сделать на данный момент, прост: сохранение данных через основной поток. Однако теперь возникает новая проблема: тупик. Приложение становится невосприимчивым, потому что за каждой из моих вставок нового NSManagedObject следует вызов для сохранения. (это мое лучшее предположение).
Чтение документации делегата приложения, я заметил, что он рекомендует мне сохранять контекст в applicationWillTerminate.
Мой вопрос таков: Для длительной работы, которая каждую минуту вставляет новые события, и пользователю не требуется сразу получать обновления, распространяемые на всех контроллерах, когда мне остается время сохранить контекст У меня возникает ощущение, что сохранение контекста для каждой записи может быть излишним?
-(void)insertNewEvent
{
// Create a new instance of the entity managed by the fetched results controller.
NSManagedObjectContext *context = [self.fetchedResultsController.managedObjectContext];
NSEntityDescription *entity = [[self.fetchedResultsControllerfetchRequest] entity];
Event*newManagedObject = (Event*)[NSEntityDescription insertNewObjectForEntityForName:[entity name] inManagedObjectContext:context];
//use accessor methods to set default values
// Save the context. > IS THIS REALLY NEEDED HERE?
NSError *error = nil;
if (![context save:&error])
{
}else
{
if(newManagedObject!=nil)
{
currentState= newManagedObject;
[currentRecord addEvent:newManagedObject];
//Is this call needed?
[self saveApplicationRecords];
}
}
}
У меня есть методы, подобные этим для всех моих управляемых объектов, достаточно ли этого, если я вызываю такой метод в основном потоке каждые 10-15 минут, чтобы сохранить ожидающие изменения, а не делать это после каждой записи?
-(void)saveApplicationRecords
{
NSLog(@"saveApplicationRecords");
NSManagedObjectContext *context = [self.applicationRecordsController.managedObjectContext];
// Save the context.
NSError *error = nil;
if (![context save:&error])
{
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
}
}
Дополнительный вопрос после чтения ответа macbirdie: является ли этот метод законным в основных данных?
-(Event*)insertAndReturnNewEventWithDate:(NSDate*)date_ type:(int)type
{
NSManagedObjectContext *context = [self.dreamEventsController managedObjectContext];
NSEntityDescription *entity = [[self.dreamEventsController fetchRequest] entity];
DreamEvent *newManagedObject = (Event*)[NSEntityDescription insertNewObjectForEntityForName:[entity name] inManagedObjectContext:context];
//handle properties
NSError *error = nil;
if (![context save:&error])
{
return nil;
}else
{
return newManagedObject ;
}
}
Спасибо!