2

我是 iOS 开发新手。我正在编写一个允许用户读取/写入核心数据记录的 iOS 应用程序。这些记录将通过 http 同步到服务器。我有一组在执行同步的后台线程中运行的链式(串行)NSOperations。

用户可以在同步我们运行的同时读/写。我的计划是在应用程序中使用两个 managedObjectContexts(都使用相同的 persistentStoreCoordinator),一个用于前台,一个用于后台。

我的 NSOperations 创建的所有后台线程都将连续运行并使用后台 MOC。所有基于 UI 的东西都将使用前台 MOC。

我的问题是:这是可接受的 iOS 核心数据模式吗?我可以愉快地在这两个 MOC 中对同一个模型数据库进行读/写操作,而不必担心锁定和并发问题吗?

非常感谢。

4

1 回答 1

3

这是一种常见的核心数据模式,框架旨在适应这种模式。

如果您自己管理线程,则需要使用一种称为“线程限制”的技术,您可以在标题为“与核心数据的并发”部分的文档中阅读更多相关信息。

除了线程限制之外,iOS 5.0 中还有旨在帮助管理并发的新功能。现在可以NSManagedObjectContext使用NSManagedObjectContextConcurrencyType. 您可以在 aNSMainQueueConcurrencyType和之间进行选择NSPrivateQueueConcurrencyType

在主线程上运行的上下文,NSMainQueueConcurrencyType可用于为 UI 提供服务。上下文NSPrivateQueueConcurrencyType用于后台任务。

performBlock:要使用私有上下文,您可以通过和方法与之交互,performBlockAndWait:以确保您的代码在正确的线程上执行。要使用主队列上下文,您可以正常与它交互,或者如果您的代码未在主线程上运行,则使用块方法。

这些新功能在文档中没有详细讨论,在“iOS v5.0 的核心数据发布说明”部分中有一些信息。然而,WWDC 2012 会议视频中有更深入的讨论:“Session 214 - Core Data Best Practices”。

于 2012-07-21T12:23:43.933 回答