CoreData整理(三)——MagicalRecord的使用
目录
- MagicalRecord提供的使用方法
- MagicalRecord进行CRUD操作
MagicalRecord提供的使用方法
MagicalRecord是对CoreData进行了一次封装,封装了多线程Core Data中复杂的操作,并提供了丰富的封装方法,使用起来代码清晰简洁。
MagicalRecord框架提供了两个公共的MOC,rootSavingContext用于负责与PSC对接,在后台线程处理各种耗时操作,defaultContext绑定了主队列。API方法提供了两套多线程方法,其实这两种也挺类似的,都是使用了MOC的父子关系。
方法一
MagicalRecord+Actions.h文件中提供了如下几个类方法用于操作。
+ (void) saveWithBlock:(void (^ __MR_nonnull)(NSManagedObjectContext * __MR_nonnull localContext))block;
+ (void) saveWithBlock:(void (^ __MR_nonnull)(NSManagedObjectContext * __MR_nonnull localContext))block completion:(MR_nullable MRSaveCompletionHandler)completion;
+ (void) saveWithBlockAndWait:(void (^ __MR_nonnull)(NSManagedObjectContext * __MR_nonnull localContext))block;
这几个方法都是在rootSavingContext上加一个子context,并使用子context进行save。
对应的关系图如下:
方法二
NSManagedObjectContext+MagicalChainSave.h文件中提供了如下几个实例方法用于操作。
- (void)MR_saveWithBlock:(void (^ __MR_nonnull)(NSManagedObjectContext * __MR_nonnull localContext))block;
- (void)MR_saveWithBlock:(void (^ __MR_nonnull)(NSManagedObjectContext * __MR_nonnull localContext))block completion:(MR_nullable MRSaveCompletionHandler)completion;
- (void)MR_saveWithBlockAndWait:(void (^ __MR_nonnull)(NSManagedObjectContext * __MR_nonnull localContext))block;
这几个方法都是在调用方法的context上加一个子context,并使用子context进行save。所以使用时一般使用rootSavingContext或defaultContext去执行。
当使用rootSavingContext时对应的关系图同方法一,当使用defaultContext时对应的关系图如下:
MagicalRecord进行CRUD操作
为求不同,方法二就使用defaultContext进行操作。
增:
删:
改:
查:
后续
CoreData整理(一)——基本概念与简单使用
CoreData整理(二)——多线程方案
CoreData整理(四)——数据迁移和其他问题
Demo地址
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。