使用Core Data保存数据时出现故障

时间:2016-03-14 09:17:26

标签: ios swift core-data fault

我正在使用核心数据来保存iOS应用的数据。它的多线程应用程序;多个线程可以将数据保存到Core Data DB中。实际上,使用Core Data保存数据时会出现故障。

以下是打印出故障的代码:

 public func saveChanges()
{
    self.managedObjectContext.performBlock { () -> Void in

        if self.managedObjectContext.hasChanges {
            do {
                try self.managedObjectContext.save()
            } catch {
                //Handle Error
                //Handle Error, offcourse we will return after that
                print("======================================================")
                print("Error while saving 1rd tier context")
                print("------------------------------------------------------")

                let saveError = error as NSError

                print("Unable to Save Note")
                //print("\(saveError), \(saveError.localizedDescription)")

                let detailedErrors = saveError.userInfo[NSDetailedErrorsKey] as? [NSError]

                if let _ = detailedErrors {
                    for detailedError:NSError in detailedErrors! {
                        print("----------------------------------------")
                        print(" DetailedError:\(detailedError.userInfo)")
                        print("----------------------------------------")
                    }
                }

                print("------------------------------------------------------")
                print("\(saveError.localizedDescription)")
                print("======================================================")

                return
            }
        }
    }
}

以下是控制台上的日志(显示简短日志形式):

 DetailedError:[Dangling reference to an invalid object.: <null>, NSValidationErrorValue: Relationship 'emails' on managed object (0x7ff2149f9220) <UserDB: 0x7ff2149f9220> (entity: UserDB; id: 0x7ff214a20270 <x-coredata:///UserDB/t45022E2A-2772-4525-8D96-929D1AC8FD7D8> ; data: {
addressBookContacts =     (
);
bio = nil;

还有一些:

)}, NSAffectedObjectsErrorKey: (
"<Email: 0x7ff214d05c40> (entity: Email; id: 0x7ff214a6d420 <x-coredata:///Email/t45022E2A-2772-4525-8D96-929D1AC8FD7D9> ; data: {\n    emailRemovedByUser = nil;\n    \"email_address\" = nil;\n    \"email_type\" = nil;\n    id = 0;\n    \"is_verified\" = nil;\n    \"social_media_source\" = nil;\n    user = \"0x7ff214a20270 <x-coredata:///UserDB/t45022E2A-2772-4525-8D96-929D1AC8FD7D8>\";\n    visibility = 0;\n})"`), NSValidationErrorObject: <UserDB: 0x7ff2149f9220> (entity: UserDB; id: 0x7ff214a20270 <x-coredata:///UserDB/t45022E2A-2772-4525-8D96-929D1AC8FD7D8> ; data: {
addressBookContacts =     (

它还显示“悬挂对无效对象的引用”;我坚持这个问题..并且无法理解为什么会发生这种情况。

有人观察过这类问题吗?有什么建议吗?

1 个答案:

答案 0 :(得分:0)

从多个线程管理核心数据真的很危险。

您只有两种方法可以使用CD:

  • 线程限制:所有调用读取/写入核心数据的都是在同一个线程上进行的(通常这是主线程)
  • 多上下文:您可以按线程创建一个托管对象上下文,但这很难,您不想这样做

所以我建议你使用主线程来执行所有的调用。 (并检查你的上下文是否真的在主线程中设置)