由于NSManagedObjectContextObjectsDidChangeNotification导致的运行时错误

时间:2017-07-31 11:03:47

标签: ios core-data runtime-error dbcontext nsmanagedobjectcontext

我遇到了这个运行时错误,它在刷新数据或启动时发生了50%的时间(从服务中获取并保存在coreData中)。我已经查看了几乎关于这个问题的所有解决方案,但大多数都在Obj-C中,但我是iOS新手并使用swift。我有大约20个表,所有表都使用相同的上下文。

以下是我的代码:

public class ServiceCalls : NSManagedObject {
  /*
             class func getContext () -> NSManagedObjectContext {
        let appDelegate = UIApplication.shared.delegate as! AppDelegate

        let moc = NSManagedObjectContext(concurrencyType:.mainQueueConcurrencyType)
        let privateMOC = NSManagedObjectContext(concurrencyType: .privateQueueConcurrencyType)
        privateMOC.parent = moc

        privateMOC.perform({
            do {
                try privateMOC.save()
            } catch {
                fatalError("Failure to save context: \(error)")
            }
        })
        return appDelegate.persistentContainer.viewContext
    }
             */ // tried this but didn't work

     class func getContext () -> NSManagedObjectContext {
        let appDelegate = UIApplication.shared.delegate as! AppDelegate
        return appDelegate.persistentContainer.viewContext
    }

这就是我使用它的方式,下面只是在数据库中保存数据的一个例子。

class func SaveCustomerContacts(name : String,id : String){

let context = getContext()
let entity =  NSEntityDescription.entity(forEntityName: "AllCustomerContacts_Tbl", in: context)
let newDoc = NSManagedObject(entity: entity!, insertInto: context)

newDoc.setValue(name, forKey: "contactName")
newDoc.setValue(id, forKey: "id") 



    //save the object
do {
    try context.save()
    print("saved Customer contacts in Database yayy!")

} catch let error as NSError  {
    print("Could not save \(error), \(error.userInfo)")
} catch {
    let nserror = error as NSError
    fatalError("Unresolved error \(nserror), \(nserror.userInfo)")
}
}

这是抛出的完整异常:

    [error] 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)
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)
2017-07-31 16:09:20.908 Sales CRM[5846:202190] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSCFSet addObject:]: attempt to insert nil'
*** First throw call stack:

1 个答案:

答案 0 :(得分:0)

错误表示正在插入一些nil值。

[error] 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)
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)
2017-07-31 16:09:20.908 Sales CRM[5846:202190] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSCFSet addObject:]: attempt to insert nil'
*** First throw call stack:

这个问题可能有很多原因:

  1. 您正在使用多个上下文,并且无法正确处理它们。
  2. 您正尝试在后台保存并发类型为MainQueueConcurrencyType的上下文。请改用PrivateQueueConcurrencyType
  3. 保存的值为nil或某种错误数据(关系中)。