开发者

Core Data, MOCs, and multi-threading

A conceptual question:

I have data stored hierarchically via Core Data SQLite for an iPhone app. I wish both to draw AND to perform calculations based upon properties of each object in the entire hierarchical arrangement of objects. Both drawing and calculating tasks access the same exact properties. Simple enough. However, I an开发者_StackOverflow中文版ticipate that performing both drawing and calculation on the main thread will cause some problems with UI responsiveness. Using two MOCs to access the same data but on different threads sounds a little silly to me at first pass (traversing the tree twice, once in each thread). Honestly, I'm not convinced multi-threading would help too much.

Would someone enumerate generic options for achieving reasonable app performance in this particular case?

Thanks.


First, and always, don't make design decisions of this type without actual performance data. You need to profile both the single and multi-threaded approaches. That said, best practices for multi-threading with Core Data dictate one NSManagedObjectContext per-thread, but a single NSPersistentStoreCoordinator. Because row-level caching is done in the persistent store coordinator, it's possible that your multiple-traversals will not incur an unreasonable overhead.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜