Okazjonalne czytelnik i pierwszy raz Pytający pytanie, więc proszę być łagodne :)Nieprawidłowy błąd danych rdzenia spowodowany nadmiernym zwolnieniem?
Tworzę zarządzanego obiektu (rachunku), które jest przekazywane do kontrolera widoku gdzie jego dziecko jest ustawiony w nieruchomości, która jest zatrzymany.
Account * account = [[Account alloc] initWithEntity:entity insertIntoManagedObjectContext:context];
AddAccountViewController *childController = [[AddAccountViewController alloc] init];
childController.title = @"Account Details";
childController.anAccount = account;
childController.delegate = self;
[self.navigationController pushViewController:childController animated:YES];
[childController release];
[account release];
Widok Controller Interface:
@interface AddAccountViewController : UIViewController {
}
@property (nonatomic, retain) IBOutlet UITextField * usernameTextField;
@property (nonatomic, retain) IBOutlet UITextField * passwordTextField;
@property (nonatomic, retain) Account * anAccount;
@property (nonatomic, assign) id <AddAccountDelegate> delegate;
- (IBAction)cancel:(id)sender;
- (IBAction)add:(id)sender;
- (IBAction)textFieldDone:(id)sender;
@end
więc w przykładowym kodzie 1 Mam zwolniony obiekt konta, bo nie interesuje mnie w tej metodzie. Ponieważ jest on przechowywany przez AddAccountViewController Mam wpis w 'AddAccountViewController' s dealloc, który go zwalnia.
Jednak kiedy idę, aby usunąć obiekt z ManagedObjectContext Aplikacja ulega awarii z następującym (raczej niejasny) Błąd:
Detected an attempt to call a symbol in system libraries that is not present on the iPhone:
_Unwind_Resume called from function _PFFaultHandlerLookupRow in image CoreData.
Po wielu debugowania & ciągnięcie za włosy odkryłem, że jeśli ja nie Uwolnij konto w metodzie AddAccountViewController 's dealloc metoda działa poprawnie i nie wydaje się przeciekać zgodnie z Instruments.
Czy ktoś może rzucić światło na to, co się dzieje? Rozumiem z dokumentów o właściwościach, które zatrzymane muszą zostać zwolnione. Co przeoczyłem?
Aktualizacja odpowiedzieć na pytanie Kevina
kod, aby usunąć obiekt z ManagedObjectContext jest w RootViewController (czyli posiadających kontroler dziecko)
// Override to support editing the table view.
- (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath {
if (editingStyle == UITableViewCellEditingStyleDelete) {
// Delete the managed object for the given index path
NSManagedObjectContext *context = [self.fetchedResultsController managedObjectContext];
[context deleteObject:[self.fetchedResultsController objectAtIndexPath:indexPath]];
// Save the context.
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. 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();
}
}
}
Czy można wyświetlić kod, który usuwa go z NSManagedObjectContext? I dzieje się to wewnątrz AddAccountViewController lub gdzie indziej? –
'childController.anAccount = account;' ta linia NIE zachowuje 'konta'. Kopiuje go do "konta ana". To w ogóle nie daje +1, a będziesz musiał zwolnić 'anAccount' w metodzie dealloc AddAccountViewcontroller. –
@Thomas: '@property (nonatomic, retain) Konto * anAccount;' Dlaczego by nie zachował? – Pyetras