0

Person エンティティと Picture エンティティを持つモデルがあります。私の Picture エンティティには、Person との関係であるプロパティがあります。

私がやったことはうまくいかないので、人に写真を追加する方法の例が欲しいです。

-(BOOL)savePicture:(NSString *)urlPicture:(Person *)person{
SettingsSingleton *userSettings = [SettingsSingleton sharedManager];    
NSManagedObjectContext *managedObjectContext = [userSettings managedObjectContext]; 
NSEntityDescription *myContentEntity = [NSEntityDescription entityForName:@"Pictures" inManagedObjectContext:managedObjectContext];
NSManagedObject *contentToSave = [[NSManagedObject alloc] initWithEntity:myContentEntity insertIntoManagedObjectContext:managedObjectContext];

[contentToSave setValue:urlPicture forKey:@"url"];
[contentToSave setValue:person forKey:@"relatedPerson"];

[managedObjectContext insertObject:contentToSave];  

NSError *error;
if ([managedObjectContext save:&error]){
    //Deal with errors
    NSLog(@"Error");
            return NO; 
}
return YES;
}

if ([managedObjectContext save:&error]) 行でクラッシュし、コンソールにこれらのエラーがあります:

-[UITableViewCell objectID]: unrecognized selector sent to instance 0x135c2b0 Serious application error.  Exception was caught during Core Data change processing: ***     
-[UITableViewCell objectID]: unrecognized selector sent to instance 0x135c2b0 with userInfo (null) *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '*** 
-[UITableViewCell objectID]: unrecognized selector sent to instance 0x135c2b0'

以前のビューでは、次のコードがあります

- (void)viewDidLoad {
[super viewDidLoad];
SettingsSingleton *settings = [SettingsSingleton sharedManager];    
managedObjectContext = [settings managedObjectContext]; 
fetchedResultsController = [settings fetchedResultsController];
fetchedResultsController.delegate=self;

NSError *error;
if (![[self fetchedResultsController] performFetch:&error]) {
    // Handle the error...
}
[settings release];

self.table = [[UITableView alloc] initWithFrame:CGRectMake(0, 0, 320, 416)  style: UITableViewStyleGrouped];
[table setDataSource:self];
table.delegate=self;
[self.view addSubview: self.table];
}


- (NSFetchedResultsController *)fetchedResultsController {

if (fetchedResultsController != nil) {
    return fetchedResultsController;
}

Person *personTmp=[[Person alloc] init];
personTmp=[personTmp getPersonById:self.personId];

/*
 Set up the fetched results controller.
 */
// Create the fetch request for the entity.
NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
// Edit the entity name as appropriate.
NSEntityDescription *entity = [NSEntityDescription entityForName:@"Pictures" inManagedObjectContext:managedObjectContext];
NSPredicate *predicate =[NSPredicate predicateWithFormat:@"relatedPerson == %@ AND contentType == %d",personTmp, CONTENT_DATA_PICTURE];

[fetchRequest setEntity:entity];
[fetchRequest setPredicate:predicate];

// Edit the section name key path and cache name if appropriate.
// nil for section name key path means "no sections".
NSFetchedResultsController *aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:managedObjectContext sectionNameKeyPath:nil cacheName:@"Root"];
aFetchedResultsController.delegate = self;
self.fetchedResultsController = aFetchedResultsController;

[aFetchedResultsController release];
[fetchRequest release];
[predicate release];
[personTmp release];


return fetchedResultsController;
}    


- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

static NSString *CellIdentifier = @"Cell";

UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
if (cell == nil) {
    cell = [[[UITableViewCell alloc] initWithFrame:CGRectZero reuseIdentifier:CellIdentifier] autorelease];
    cell.accessoryType = UITableViewCellAccessoryDisclosureIndicator;
}
if(indexPath.row==0){
    cell.textLabel.text=@"Add a picture";
}
else{
    int nb=indexPath.row-1;
    NSIndexPath *ip = [NSIndexPath indexPathForRow: nb inSection:indexPath.section];
    NSManagedObject *managedObject = [fetchedResultsController  objectAtIndexPath:ip];
    cell.textLabel.text = [[managedObject valueForKey:@"url"] description];
    [ip release];
}
return cell;
}


- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
int nb=[[fetchedResultsController sections] count];
if (nb == 0) {
    nb = 1;
}
return nb;
}


- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

NSArray *sections = [fetchedResultsController sections];
NSUInteger count = 0;
if ([sections count]) {
    id <NSFetchedResultsSectionInfo> sectionInfo = [sections objectAtIndex:section];
    count = [sectionInfo numberOfObjects];
}
return count+1;
}
4

2 に答える 2

6

非常によく似たエラーが発生しました。最初にcustomTypeA viewControllerをロードし、次にその上にcustomTypeB viewControllerをロードするnavControllerがありました。これらの viewController はどちらも、Core Data と fetchedResultsControllers を tableview のデータ ソースとして使用しました。customTypeB の機能は、customTypeA のデータソースに新しいデータ オブジェクトを追加することでした。そうすると、上記のエラー " Serious Error in Core Data, Unrecognized Selector. EXC_BAD_ACCESS" が表示されます。ただし、認識されないセレクターは「controllerWillChangeContent」であるとエラーが表示されました。私のviewControllerは両方とも、fetchedViewControllerデリゲートメソッド「controllerWillChangeContent、controllerDidChangeObject ...、controllerDidChangeContent」を利用しました。

viewControllerB が controllerA のデータを変更すると、controllerB がまだ「ポップ」されていなくても、controllerA の fetchedResultsController がアクティブになることに気付きました。したがって、おそらく controllerB のデリゲートが呼び出されていると考えました。Core Data プログラミング ドキュメントを見ると、fetchedResultsController を使用して各ビューに推奨されていることがわかりました。viewWillDisappear を実装し、その中に fetchedResultsController = nil; を設定する必要があります。私にとって、これは私の問題を解決しました。

また、参考までに、Snow Leopard用のXCODE 3.2をインストールする前に、表示されないviewControllerのfetchedResultsControllersのデリゲートが呼び出されるというこの問題はありませんでした。コードは Leopard の Xcode3.1 で問題なく動作していました。

于 2009-09-21T08:29:31.270 に答える
1

まず、「insertObject」を呼び出す必要はありません。アップルのドキュメントから:

context が nil でない場合、このメソッドは [context insertObject:self] を呼び出します (これにより、awakeFromInsert が呼び出されます)。

したがって、オブジェクトを 2 回冗長に挿入しています。これがどのような悪影響をもたらすかはわかりませんが、良いことにはなりません。

エラーに関しては、コードの他の部分が原因のようです。このメッセージの基本的な意味は、UITableViewCell の CoreData objectID にアクセスしようとしていることです。これは保存中に発生するため、この関数の前のある時点で、UITableViewCell を managedObjectContext に挿入している可能性があり、実際に保存するときにここで吹き飛ばすだけだと思います。

于 2009-09-03T20:59:47.423 に答える