Базовые объекты данных не будут храниться - PullRequest
1 голос
/ 06 марта 2012

Я начал интегрировать основные данные в свой текущий проект, и я впервые работаю с ним.

Мне удалось записать новые объекты в мой NSManagedObjectContext и прочитать их.Моя проблема в том, что после закрытия приложения все объекты теряются.Вот одна из функций, которая добавляет новые объекты:

-(void)addExpenseWithValue:(NSNumber *)value name:(NSString *)name type:(BOOL)type andDate:(NSDate *)date{

//get the right managed object context
NSManagedObjectContext *context = self.managedObjectContext;      

//creat a new expense in context
NSManagedObject *newExpense = [NSEntityDescription insertNewObjectForEntityForName:@"Expense" inManagedObjectContext:context];

//Get Number representation of month and year
NSNumber *monthNumber = [self getMonthNumber:date];
NSNumber *dayNumber = [self getDayNumber:date];

//set values of the expense
[newExpense setValue:[NSDate date] forKey:@"date"];
[newExpense setValue:value forKey:@"value"];
[newExpense setValue:name forKey:@"name"];
[newExpense setValue:[NSNumber numberWithBool:type ] forKey:@"expenseType"];
[newExpense setValue:monthNumber forKey:@"month"];
[newExpense setValue:dayNumber forKey:@"day"];
[self storeData];
}


-(void)storeData{
NSError *error = nil;
[managedObjectContext save:&error];

}

объекты на самом деле хранятся, и я могу прочитать их позже.насколько я знаю, это как-то связано с persistentStore и persistentStoreCoordinator.В my appDelegate реализованы следующие методы:

- (NSPersistentStoreCoordinator *)persistentStoreCoordinator {
if (persistentStoreCoordinator != nil) {
    return persistentStoreCoordinator;
}
NSURL *storeUrl = [NSURL fileURLWithPath: [[self applicationDocumentsDirectory]
                                           stringByAppendingPathComponent: @"<Project Name>.sqlite"]];
NSError *error = nil;
persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc]
                              initWithManagedObjectModel:[self managedObjectModel]];
if(![persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType
                                             configuration:nil URL:storeUrl options:nil error:&error]) {
    /*Error for store creation should be handled in here*/
}

return persistentStoreCoordinator;
}

- (NSManagedObjectContext *) managedObjectContext {
if (managedObjectContext != nil) {
    return managedObjectContext;
}

NSPersistentStoreCoordinator *coordinator = [self persistentStoreCoordinator];
if (coordinator != nil) {
    managedObjectContext = [[NSManagedObjectContext alloc] init];
    [managedObjectContext setPersistentStoreCoordinator: coordinator];
}

return managedObjectContext;
}

 - (NSManagedObjectModel *)managedObjectModel {
if (managedObjectModel != nil) {
    return managedObjectModel;
}
managedObjectModel = [NSManagedObjectModel mergedModelFromBundles:nil] ;

return managedObjectModel;
}



- (NSString *)applicationDocumentsDirectory {
return [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
 }

ОБНОВЛЕНИЕ:

Я добавил небольшую тестовую функцию, для эксперимента она вызывается в первом viewController:

-(void)test{

NSArray* stores = [[managedObjectContext persistentStoreCoordinator]persistentStores];
if ([stores objectAtIndex:0]==nil) {
    NSLog(@"no stores found");
}
else
    NSLog(@"%d", [stores count]);

}

managedObjectContext - это приложения NSanagedObjectContext, инициированные в приложении appdelegate.он существует, массив выделяется, но счет остается на уровне 0.

2012-03-06 20:09:37.772 DailyBudget[1533:fb03] *** Terminating app due to uncaught
exception 'NSRangeException', reason: '*** -[__NSArrayI objectAtIndex:]: index 0 beyond      
bounds for empty array'
*** First throw call stack:
(0x135f052 0x174fd0a 0x134b674 0x3c6a 0x3894 0x46cfbf 0x46d21b 0x4838b1 0x46cfbf
0x46d21b 0x46e0f1 0x3dcfec 0x3e2572 0x3dc72b 0x3cbbc2 0x3cbce2 0x3cbea8 0x3d2d9a 0x25b3 
0x3a39d6 0x3a48a6 0x3b3743 0x3b41f8 0x3a7aa9 0x1f57fa9 0x13331c5 0x1298022 0x129690a
0x1295db4 0x1295ccb 0x3a42a7 0x3a5a9b 0x2488 0x23e5 0x1)
terminate called throwing an exception(gdb) 

в момент ошибки у меня есть следующие объекты:

objects that exist

что мне не хватает?

1 Ответ

0 голосов
/ 07 марта 2012

... 24 часа спустя. я как-то смог решить это сам =) Я думаю, что проблема лежала в storeURL. мой новый код был вдохновлен этим постом здесь:

Добавление CoreData в существующий проект (theappcodeblog.com)

спасибо за ваши ребята за проверку в любом случае =)

новый код (рабочий):

NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"CoreDataTabBarTutorial.sqlite"];

с функцией

- (NSURL *)applicationDocumentsDirectory {
    return [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject];
}
...