Я загружаю кучу данных из текстового файла в CoreData. По какой-то причине каждая итерация цикла for (строка в строках) в приведенном ниже коде выделяет новую память. Работает нормально до тех пор, пока не сможет выделить новую память. Я не понимаю, почему он не использует одну и ту же память для каждой итерации. Что я делаю неправильно? Любая помощь будет оценена.
`
- (IBAction) loadDataInThread {
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
NSString *filePath = [[NSBundle mainBundle] pathForResource:@"MileMarkers" ofType:@"csv"];
NSData *myString = [NSString stringWithContentsOfFile:filePath];
NSArray *lines = [myString componentsSeparatedByString:@"\r"];
status.hidden = FALSE;
// NSManagedObjectContext *context = [self managedObjectContext];
NSFileManager *fileman = [NSFileManager defaultManager];
NSString *tileDirectory = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:@"Tiles"];
NSString *line;
NSNumberFormatter * myNumFormatter = [[NSNumberFormatter alloc] init];
[myNumFormatter setLocale:[NSLocale currentLocale]];
[myNumFormatter setFormatterBehavior:NSNumberFormatterBehavior10_4];
[myNumFormatter setNumberStyle:NSNumberFormatterDecimalStyle];
NSManagedObject *newManagedObject;
NSArray *fields;
// NSLog(@"Loading Markers");
for (line in lines) {
fields = [line componentsSeparatedByString:@","];
self.stat = [NSString stringWithFormat:@"%@ %@ %@ %@",[fields objectAtIndex:0],[fields objectAtIndex:1],[fields objectAtIndex:2],[fields objectAtIndex:3]];
NSLog(stat);
[self performSelectorOnMainThread:@selector(updateStatus) withObject:nil waitUntilDone:YES];
newManagedObject = [NSEntityDescription insertNewObjectForEntityForName:@"MileMarkers" inManagedObjectContext:self.managedObjectContext];
NSNumber *f1 = [myNumFormatter numberFromString:[fields objectAtIndex:0]];
NSNumber *f2 = [myNumFormatter numberFromString:[fields objectAtIndex:1]];
NSNumber *f3 = [myNumFormatter numberFromString:[fields objectAtIndex:2]];
NSNumber *f4 = [myNumFormatter numberFromString:[fields objectAtIndex:3]];
[newManagedObject setValue:f1 forKey:@"ICWID"];
[newManagedObject setValue:f2 forKey:@"MileMarker"];
[newManagedObject setValue:f3 forKey:@"Latitude"];
[newManagedObject setValue:f4 forKey:@"Longitude"];
NSMutableArray *charts = [[NSMutableArray alloc] initWithCapacity:4];
NSDirectoryEnumerator *e = [fileman enumeratorAtPath:tileDirectory];
NSString *path;
int idx = 0;
/*
for (path in e) {
NSString *pathFileName = [NSString stringWithFormat:@"%@/%@/tilemapresource.xml",tileDirectory,[path stringByDeletingPathExtension]];
// NSLog(@"parsing %@",pathFileName);
BOOL checkFile = [self checkForLatLong:pathFileName latitude:f3 longitude:f4 ];
if (checkFile) {
NSLog(@"Match %d",idx);
if (idx < 4){
self.counter.text = [NSString stringWithFormat:@"%d",idx];
[charts insertObject:path atIndex:idx];
idx++;
}
}
}
[path release];
for (int lp=1; lp<[charts count]; lp++) {
NSString *keyName = [NSString stringWithFormat:@"Chart%d",lp+1];
[newManagedObject setValue:[charts objectAtIndex:lp] forKey:keyName];
}
[charts release];
*/
NSError *error = nil;
if (![self.managedObjectContext 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. If it is not possible to recover from the error, display an alert panel that instructs the user to quit the application by pressing the Home button.
*/
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}
[error release];
}
[myNumFormatter release];
NSLog(@"Markers Loaded");
[self performSelectorOnMainThread:@selector(dataLoaded) withObject:nil waitUntilDone:YES];
[pool release];
}
`