Gelegenheitsleser und zum ersten Mal Frage Fragesteller, so wenden Sie sich bitte :)Odd Core Data Fehler durch Überlösen verursacht?
Ich erstelle ein Managed Object (Account) sanft, ist, dass in ein Kind-View-Controller wird geleitet, wo seine in einer Eigenschaft festgelegt wird, die ist beibehalten.
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];
Die View-Controller-Schnittstelle:
@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
So in Codebeispiel 1 I das Konto Objekt freigegeben habe, weil ich nicht mehr interessiert bin in es in diesem Verfahren. Wie es von der AddAccountViewController beibehalten wird, habe ich einen Eintrag in AddAccountViewControllerdealloc, die es freigibt.
aber wenn ich das Objekt aus dem ManagedObjectContext den App-Abstürzen mit den folgenden (eher unklar) Fehlern zu löschen:
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.
Nach vielen Debuggen & Haaren ziehen ich entdecken, wenn ich nicht Release-Konto in AddAccountViewControllerdealloc Methode die App funktioniert ordnungsgemäß kontinuierlich und scheint nicht zu lecken nach Instrumenten.
Kann jemand Licht über das Geschehen werfen? Aus den Dokumenten über Eigenschaften geht hervor, dass diese beibehalten werden müssen. Was habe ich verpasst?
aktualisieren Kevins Frage zu beantworten
Der Code des Objekts aus dem ManagedObjectContext ist in der RootViewController (das Halten des Kindes Controller)
// 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();
}
}
}
Können Sie den Code zeigen, dass sie von der NSManagedObjectContext löscht? Und geschieht dies innerhalb von AddAccountViewController oder anderswo? –
'childController.anAccount = account;' In dieser Zeile wird 'account' nicht gespeichert. Es kopiert es in "anAccount". Dies wird nicht beibehalten, und Sie müssen nur 'anAccount' in der Dealloc-Methode' AddAccountViewcontroller' freigeben. –
@Thomas: '@property (nonatomic, behalten) Konto * anAccount;' Warum würde es nicht beibehalten? – Pyetras