Core data/MagicalRecord Concurrency Reseach
来源:互联网 发布:pureVPN软件 编辑:程序博客网 时间:2024/06/01 10:36
Core data research
- 每个线程必须有自己的NSManagedObjectContext
- NSManagedObjects不是线程安全的,但是NSManagedObjectIDs是线程安全的
- 如果在background保存,则需要通过core data Notification将changes同步到其他contexts
参考:
Concurrency with Core Data
Core Data Overview
How MagicalRecord resolve multi-threading concurrency issue
以下为异步保存的code
12345678910111213
Person *person = ...;[MagicalRecord saveWithBlock:^(NSManagedObjectContext *localContext){ Person *localPerson = [person MR_inContext:localContext]; localPerson.firstName = @"John"; localPerson.lastName = @"Appleseed";} completion:^(BOOL success, NSError *error) { self.everyoneInTheDepartment = [Person findAll];}];
如以上例子,在block里的save操作不会在main thread里,以独立的NSManagedObjectContext来工作。任务完成后,completion block将会被main thread调用,可以安全的更新UI部分。 操作对象NSManagedObject是通过NSManagedObjectID来得到的,在当前context中安全使用。
saveWithBlock如何工作
- 创建一个NSPrivateQueueConcurrencyType类型的NSManagedObjectContext,parentConext为rootSavingContext
- 设置notification
- 回调block,返回新建立的context
- 如果有任何改动,保存当前context
- rootSavingContext同样会被保存
- Main thread的default context将会通过notification机制merge此改动
- main thread中回调completion,返回是否成功和error code
参考:
CORE DATA AND THREADS, WITHOUT THE HEADACHE
Performing Core Data operations on Threads
Conclusion
MagicalRecord非常好的解决了core data多线程并发问题,我们只需要使用好MagicalRecord就能解决UI界面freeze等的问题。
0 0
- Core data/MagicalRecord Concurrency Reseach
- Core Data操作模板3--MagicalRecord使用
- 怎么写基于MagicalRecord的Core Data单元测试
- MagicalRecord
- MagicalRecord
- core data
- Core Data
- Core Data
- Core Data
- Core data
- Core Data
- Core Data
- Core Data
- Core Data
- core data
- Core Data
- Core Data
- Core Data
- 老罗推荐的书
- uva 307(回溯)
- 二次剩余
- MFC 获取父窗口
- 使用 udev 高效、动态地管理 Linux 设备文件
- Core data/MagicalRecord Concurrency Reseach
- DataStage “Sort、Remove Duplicates”控件使用总结
- hdu 2159 FATE(二维完全背包)
- ListView数据动态刷新
- java 步步惊心
- Fragment(二)通信
- Android开发调试中遇到的Waiting for HOME解决方案
- [网易2012年某笔试题] 求斐波那契数列, 要求时间复杂度尽可能小(简单题,不熟悉斐波那契的同学可参考)
- 图-邻接矩阵