当我想通过下载和解析json文件来更新我的Core Data文件时,我的应用程序有时会崩溃.我收到以下错误:

CoreData: error: SerIoUs application error. Exception was caught
during Core Data change processing. This is usually a bug within an
observer of NSManagedobjectContextObjectsDidChangeNotification.
-[__NSCFSet addobject:]: attempt to insert nil with userInfo (null)

如果我在迭代期间更改属性,在迭代中保存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 – 核心数据:删除/添加对象时出错的更多相关文章

  1. ios – 如何在UIActivityViewController调用然后关闭后执行操作

    解决方法在这种情况下,您可以使用completionHadler:

  2. android – 如何在服务中正确调用startIntentSenderForResult?

    还是有其他正确的方法吗?)>然后,在onActivityResult()中,完成活动,首先通知您的服务解决问题.瞬态活动对用户来说是不可见的.我承认这个解决方案是理论上的,但它应该有效.

  3. android – Slider Menu片段中的可交换选项卡

    我已经通过引用thistutorial实现了导航抽屉,现在我想要做的是在片段内显示滑动标签.即当我点击导航抽屉中的一个项目时,让我们说第一个项目,它应显示该项目的滑动标签.如果item1是Events,当我点击它时,它应该显示滑动标签.但我面临以下问题:–>如何在片段内实现视图寻呼机?

  4. Android架构组件ViewModel – 如何在测试Activity上模拟ViewModel?

    我正在尝试设置类似于GithubbrowserSample的UI测试,看起来示例项目只有Frag的模拟viewmodel而不是Activity的示例.这是我的代码,我试图通过模拟viewmodel来测试Activity.但viewmodel未在Activity中的onCreate()之前设置.有人可以帮我解决这个问题吗?解决方法JUnit@Rules在@Before方法之前进行设置,因此您的活动在

  5. android – 如何在对话框上添加进度条

    每当我想在我的应用程序中显示进度条时,我调用此方法,此方法将ProgressBar添加到我的布局中.问题:我想在Dialog上显示此进度条,但Dialog始终显示在上面.这种情况可以做些什么?解决方法尝试这样的东西,它应该全局工作:

  6. android – 无法获得连接工厂客户端 – 与谷歌地图战斗

    另一天另一个问题,我终于设法在我的Android应用程序上设置正确的谷歌地图,或者至少我以为我已经完成了它,整个程序开始,它甚至调用应该“打印”地图的类,但是我唯一能看到的是一个带有谷歌标签的网格[在角落里].我检查了dalvik监视器和错误E/MapActivity(394):Couldn’tgetconnectionfactoryclient发生.我已经在stackoverflow网站上找到了

  7. android – 远程服务如何将消息发送到绑定的Activity?

    例如,我的活动绑定到同一个应用程序的正在运行的后台服务,向它发送一条消息,一旦收到此消息,服务就会向活动回复一条消息..我该如何实现?你能指点我一些解释这个主题的文件吗?

  8. 确定Android暂停的原因

    我的应用程序是随机暂停(进入onPause方法)然后恢复(进入onResume方法),当我甚至没有触摸屏幕.在logcat中,没有指示导致暂停和恢复的原因.这只发生在galaxyTab7“而不是MotorolaXoom或HTCLegend上.如何确定暂停的原因?解决方法你声明它只发生在galaxyTab上.我会假设设备上运行的另一个应用程序经常会添加一个不可见的叠加层.如果此叠加层位于前景,则会触

  9. Android – 在键盘上方显示BottomSheetDialogFragment

    我正在尝试显示带有一些EditText字段的BottomSheetDialogFragment,供用户输入信息.我想直接在键盘上方显示它,但它会不断覆盖内容.当我调出BottomSheetDialogFragment时会发生这种情况,您可以看到它正在选择卡号EditText,但覆盖其他内容.理想情况下,这就是我正在寻找的,你可以看到EditTexts和View的填充.我尝试了很多围绕windowS

  10. android – FLAG_ACTIVITY_CLEAR_TOP调用onCreate()而不是onResume()

    所以我有一个通过整个应用程序扩展的抽象类,它覆盖了后面的键,将ActivityA重新排序到前面(带有标志).那么,它将是:A>B>在任何地方,后面的键应该让我回到A我正在使用FLAG_ACTIVITY_CLEAR_TOP,但由于某些原因它完全令人耳目一新,我不希望这样.所以:Flag_activity_clear_top正在重新加载onCreate()而不是onResume().是什么赋予了?解决

随机推荐

  1. iOS实现拖拽View跟随手指浮动效果

    这篇文章主要为大家详细介绍了iOS实现拖拽View跟随手指浮动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  2. iOS – genstrings:无法连接到输出目录en.lproj

    使用我桌面上的项目文件夹,我启动终端输入:cd然后将我的项目文件夹拖到终端,它给了我路径.然后我将这行代码粘贴到终端中找.-name*.m|xargsgenstrings-oen.lproj我在终端中收到此错误消息:genstrings:无法连接到输出目录en.lproj它多次打印这行,然后说我的项目是一个目录的路径?没有.strings文件.对我做错了什么的想法?

  3. iOS 7 UIButtonBarItem图像没有色调

    如何确保按钮图标采用全局色调?解决方法只是想将其转换为根注释,以便为“回答”复选标记提供更好的上下文,并提供更好的格式.我能想出这个!

  4. ios – 在自定义相机层的AVFoundation中自动对焦和自动曝光

    为AVFoundation定制图层相机创建精确的自动对焦和曝光的最佳方法是什么?

  5. ios – Xcode找不到Alamofire,错误:没有这样的模块’Alamofire’

    我正在尝试按照github(https://github.com/Alamofire/Alamofire#cocoapods)指令将Alamofire包含在我的Swift项目中.我创建了一个新项目,导航到项目目录并运行此命令sudogeminstallcocoapods.然后我面临以下错误:搜索后我设法通过运行此命令安装cocoapodssudogeminstall-n/usr/local/bin

  6. ios – 在没有iPhone6s或更新的情况下测试ARKit

    我在决定下载Xcode9之前.我想玩新的框架–ARKit.我知道要用ARKit运行app我需要一个带有A9芯片或更新版本的设备.不幸的是我有一个较旧的.我的问题是已经下载了新Xcode的人.在我的情况下有可能运行ARKit应用程序吗?那个或其他任何模拟器?任何想法或我将不得不购买新设备?解决方法任何iOS11设备都可以使用ARKit,但是具有高质量AR体验的全球跟踪功能需要使用A9或更高版本处理器的设备.使用iOS11测试版更新您的设备是必要的.

  7. 将iOS应用移植到Android

    我们制作了一个具有2000个目标c类的退出大型iOS应用程序.我想知道有一个最佳实践指南将其移植到Android?此外,由于我们的应用程序大量使用UINavigation和UIView控制器,我想知道在Android上有类似的模型和实现.谢谢到目前为止,guenter解决方法老实说,我认为你正在计划的只是制作难以维护的糟糕代码.我意识到这听起来像很多工作,但从长远来看它会更容易,我只是将应用程序的概念“移植”到android并从头开始编写.

  8. ios – 在Swift中覆盖Objective C类方法

    我是Swift的初学者,我正在尝试在Swift项目中使用JSONModel.我想从JSONModel覆盖方法keyMapper,但我没有找到如何覆盖模型类中的Objective-C类方法.该方法的签名是:我怎样才能做到这一点?解决方法您可以像覆盖实例方法一样执行此操作,但使用class关键字除外:

  9. ios – 在WKWebView中获取链接URL

    我想在WKWebView中获取tapped链接的url.链接采用自定义格式,可触发应用中的某些操作.例如HTTP://我的网站/帮助#深层链接对讲.我这样使用KVO:这在第一次点击链接时效果很好.但是,如果我连续两次点击相同的链接,它将不报告链接点击.是否有解决方法来解决这个问题,以便我可以检测每个点击并获取链接?任何关于这个的指针都会很棒!解决方法像这样更改addobserver在observeValue函数中,您可以获得两个值

  10. ios – 在Swift的UIView中找到UILabel

    我正在尝试在我的UIViewControllers的超级视图中找到我的UILabels.这是我的代码:这是在Objective-C中推荐的方式,但是在Swift中我只得到UIViews和CALayer.我肯定在提供给这个方法的视图中有UILabel.我错过了什么?我的UIViewController中的调用:解决方法使用函数式编程概念可以更轻松地实现这一目标.

返回
顶部