HTML5   发布时间:2022-04-27  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了ios – 核心数据:删除/添加对象时出错大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
当我想通过下载和解析json文件来更新我的Core Data文件时,我的应用程序有时会崩溃.我收到以下错误

如果我在迭代期间更改属性,在迭代中保存NsmanagedObjectContext的位置是否重要?

这是我的代码

- (void) updateData
{           
    dispatch_queue_t serialdQueue;
    serialdQueue = dispatch_queue_create("update",null);
    dispatch_async(serialdQueue,^{
        [self method1];
    });
    dispatch_async(serialdQueue,^{
        [self method2];
    });
    dispatch_async(serialdQueue,^{
        [self method3];
    });
    dispatch_async(serialdQueue,^{
        [self method4];
    });
    dispatch_async(serialdQueue,^{
        [self method5];
    });

}

-(void)method1
{        
    //DOWNLOAD JSON FILE
}

-(void)method2 //here i add objects to the core data file
{        
    @try {

        for (NSDictionary *jsonActivity in [json objectForKey:@"Activities"]) {  //ITERATE THROUGH JSON ACTIVITY ARRAY

            NSFetchrequest *request = [[NSFetchrequest alloc] init];

            NSEntityDescription *entity = [NSEntityDescription entityForName:@"Activity" inManagedObjectContext:self.managedObjectContext];
            [request setEntity:entity];

            NSPreDicate *searchFilter = [NSPreDicate preDicateWithFormat:@"title == %@",[jsonActivity objectForKey:@"title"]]; // checK IF OBjeCT FROM JSON FILE ALREADY EXISTs...
            [request setPreDicate:searchFilter];
            NSError *error = nil;

            NSArray *results = [self.managedObjectContext executeFetchrequest:request error:&error];
            if (error) {
                NSLog(@"Error %@",error);
                abort();
            }

            if ([results count] == 0) { // ADD NEW ACTIVITY IF OLD LIST DOESNT CONTAIN IT

                Activity *activity = [NSEntityDescription insertNewObjectForEntityForName:@"Activity" inManagedObjectContext:self.managedObjectContext];

                activity.title = [jsonActivity objectForKey:@"title"];

                activity.remove = [NSnumber numberWithBool:NO]; // REMOVE FLAG = NO BECAUSE NEW OBjeCTS AREN'T REMOVED

            } else  {

                Activity *activity = (Activity*) [results objectATindex:0];
                activity.remove = [NSnumber numberWithBool:NO]; // IF OBjeCT ALREADY EXISTS IT SHOULD BE OBTAINED
            }

            AppDelegate *appDelegate = [[UIApplication sharedApplication] delegate];
            [appDelegate saveContext]; // SAVE MO COntexT
        }

    }   @catch (NSException *exception) {

        NSLog(@"Exception: %@",exception);
    }
}

-(void)method3 // deletE OLD OBjeCTS 
{   
    NSFetchrequest *fetchrequest = [[NSFetchrequest alloc] init];
    NSEntityDescription *entityDescription = [NSEntityDescription entityForName:@"Activity" inManagedObjectContext:self.managedObjectContext];
    [fetchrequest setEntity:entityDescription];

    NSPreDicate *searchFilter = [NSPreDicate preDicateWithFormat:@"remove == %@",[NSnumber numberWithBool:YES]];
    [fetchrequest setPreDicate:searchFilter];

    NSArray *objectsTodelete = [[NSArray alloc] init];

    NSError *error = nil;
    objectsTodelete = [self.managedObjectContext executeFetchrequest:fetchrequest error:&error];
    if (error) {
        NSLog(@"Error %@",error);
        abort();
    }

    for (Activity *activity in objectsToDelete) { // deletE OBjeCTS WITH THE PROPERTY REMOVE = YES

        [self.managedObjectContext deleteObject:activity]; // deletE ACTIVITY
    }

    AppDelegate *appDelegate = [[UIApplication sharedApplication] delegate];
    [appDelegate saveContext]; // SAVE MO COntexT
}

-(void)method4 // CHANGE THE REMOVE PROPERTY TO YES OF ALL OBjeCTS
{        
    NSFetchrequest *fetchrequest = [[NSFetchrequest alloc] init];
    NSEntityDescription *entityDescription = [NSEntityDescription entityForName:@"Activity" inManagedObjectContext:self.managedObjectContext];
    [fetchrequest setEntity:entityDescription];

    NSArray *objects = [[NSArray alloc] init];

    NSError *error = nil;
    objects = [self.managedObjectContext executeFetchrequest:fetchrequest error:&error];
    if (error) {
        NSLog(@"Error %@",error);
        abort();
    }

    for (Activity *activity in objects) {

        activity.remove = [NSnumber numberWithBool:YES];
    }

    AppDelegate *appDelegate = [[UIApplication sharedApplication] delegate];
    [appDelegate saveContext]; // SAVE MO COntexT

    NSLog(@"End update");
}

-(void)method5 //updatE UI
{
    //UI updatES
}

解决方法

您不应该在serialQueue上访问托管对象上下文.看一下 NSManagedObjectContext documentation的Concurrency部分.

如果在您的代码中您的上下文使用的是NSPrivateQueueConcurrencyType或NsmainQueueConcurrencyType并发类型,则可以使用其中一种基于块的方法来确保您处于正确的队列中:

//asyncrhonous
[self.managedObjectContext performBlock:^{
    //do stuff with the context
}];

//syncrhonous
[self.managedObjectContext performBlockAndWait:^{
    //do stuff with the context
}];

大佬总结

以上是大佬教程为你收集整理的ios – 核心数据:删除/添加对象时出错全部内容,希望文章能够帮你解决ios – 核心数据:删除/添加对象时出错所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。