- MagicalRecord提供的使用方法
- MagicalRecord進行CRUD操做
MagicalRecord是對CoreData進行了一次封裝,封裝了多線程Core Data中複雜的操做,並提供了豐富的封裝方法,使用起來代碼清晰簡潔。git
MagicalRecord框架提供了兩個公共的MOC,rootSavingContext用於負責與PSC對接,在後臺線程處理各類耗時操做,defaultContext綁定了主隊列。API方法提供了兩套多線程方法,其實這兩種也挺相似的,都是使用了MOC的父子關係。github
MagicalRecord+Actions.h文件中提供了以下幾個類方法用於操做。segmentfault
+ (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文件中提供了以下幾個實例方法用於操做。spa
- (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時對應的關係圖以下:3d
爲求不一樣,方法二就使用defaultContext進行操做。code
增:blog
刪:
改:
查:
CoreData整理(一)——基本概念與簡單使用
CoreData整理(二)——多線程方案
CoreData整理(四)——數據遷移和其餘問題
Demo地址