问题描述
我想知道是否只保存如下示例中的背景上下文就足够了,或者我还应该保存主要上下文以及原因。
extension NSManagedobjectContext {
private func saveOrRollback(context: NSManagedobjectContext) -> Bool {
do {
if context.hasChanges {
try context.save()
return true
}
} catch {
log(error,message: "Couldn't save. Rolling back.",tag: .coreData)
context.rollback()
return false
}
return false
}
func performChanges(block: @escaping () -> Void) {
let privateContext = NSManagedobjectContext(concurrencyType: .privateQueueConcurrencyType)
privateContext.parent = self
privateContext.perform {
block()
_ = self.saveOrRollback(context: privateContext)
}
}
}
解决方法
如果您想将数据保存在磁盘上,您还应该将其保存在主上下文中。
因为如果 CoreData 上下文有父上下文,那么保存数据只是将更改移动到父上下文。
替代方案: 我建议使用新的 API。您可以通过以下方式初始化 CoreData:NSPersistentContainer。 使用起来更方便。
它为用户界面创建了单独的内容:
persistentContainer.viewContext
它可以自动合并对视图上下文的更改。
persistentContainer.viewContext.automaticallyMergesChangesFromParent = true
并通过非常简单的方式对后台队列执行操作:
persistentContainer.performBackgroundTask { context in
...
do {
try context.save()
}
catch {
print(error.localizedDescription)
}
...
}
,
我想知道是否只保存如下示例中的背景上下文就足够了,或者我还应该保存主要上下文以及原因。
Core Data 托管对象上下文是一个工作区;您对数据所做的更改仅存在于该上下文中,直到您保存为止,此时更改的对象将被写回数据存储。如果您在要保留的“背景”上下文中进行了更改,则需要保存该上下文。如果您在想要持久化的“主”上下文中进行了更改,则需要保存那个上下文。
如果两个上下文之间存在父/子关系,如果您想在子上下文中永久保存更改,则需要先保存在子上下文中,然后然后保存在父上下文中语境。例如,如果您的“主”上下文是“背景”上下文的父存储,则保存在后台上下文中会将更改推送到主上下文,然后您需要保存在主上下文中。 (如果主上下文是其他上下文的子上下文,则需要一直保存到链中,直到到达根上下文。)