CoreDataManager-Swift版-兼容iOS10以前的版本

Posted 小课桌

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CoreDataManager-Swift版-兼容iOS10以前的版本相关的知识,希望对你有一定的参考价值。

  1 import UIKit
  2 import CoreData
  3 
  4 // coredata管理器
  5 class CoreDataManager: NSObject {
  6     
  7     // 单例
  8     static let sharedManager:CoreDataManager = CoreDataManager()
  9     
 10     // 私有化构造函数
 11     override private init(){
 12         super.init()
 13     }
 14     
 15     // 持久化容器,可以提供管理上下文
 16     // ios10推出,为了兼容低版本,我们这里设置private,不再使用,手动方式实现管理对象上下文,见下一个属性
 17     // 包含了CoreDataStack中的所有核心对象,下面是很重要的三个对象
 18     // viewContext: NSManagedObjectContext - 管理上下文,主要负责数据操作
 19     // managedObjectModel: NSManagedObjectModel - 管理对象模型
 20     // persistentStoreCoordinator: NSPersistentStoreCoordinator
 21     private lazy var persistentContainer: NSPersistentContainer? = {
 22         
 23         // CoreData的核心对象都不是线程安全的
 24         // 使用同步锁/互斥锁,保证线程安全
 25         objc_sync_enter(self)
 26         // 实例化对象,需要指定数据模型
 27         // 指定的名称 == 数据模型的名称 == 沙盒中数据库的名称
 28         // let container = NSPersistentContainer(name: "demo_db")
 29         
 30         // 管理对象模型,参数传入nil,自动将mainBundle中所有的数据模型合并
 31         let model = NSManagedObjectModel.mergedModel(from: nil)!
 32         
 33         // 实例化持久化容器
 34         // 参数一:数据库名字
 35         // 参数二:合并后的模型
 36         var container:NSPersistentContainer? = NSPersistentContainer(name: "ys.db", managedObjectModel: model)
 37         
 38         
 39         // “同步方式” 加载 “持久化存储” -> 本质是 打开/新建/修改数据库(同步方式,保证线程安全)
 40         container?.loadPersistentStores(completionHandler: { (storeDescription, error) in
 41             // 判断创建数据库是否出现错误
 42             if let error = error as NSError? {
 43                 /*
 44                  常见错误:
 45                  1、目录不存在,或者禁止写入,无法创建数据库文件
 46                  2、设备存储空间不足
 47                  3、由于权限或设备锁定时的数据保护,不能访问持久化存储
 48                  4、数据库不能被迁移到当前模型版本
 49                  */
 50                 print("打开/新建/修改数据库出现错误:\(error)")
 51                 container = nil
 52             }
 53         })
 54         
 55         objc_sync_exit(self)
 56         
 57         return container
 58     }()
 59     
 60     // 管理对象上下文
 61     lazy var moc:NSManagedObjectContext? = {
 62         // 同步锁/互斥锁保护
 63         objc_sync_exit(self)
 64         
 65         // 实例化管理上下文
 66         var mocObj:NSManagedObjectContext? = NSManagedObjectContext(concurrencyType: .mainQueueConcurrencyType)
 67         
 68         // 实例化对象模型
 69         let momObj = NSManagedObjectModel.mergedModel(from: nil)!
 70         
 71         // 持久化存储调度器
 72         let psc = NSPersistentStoreCoordinator(managedObjectModel: momObj)
 73         
 74         // 添加数据库
 75         // 参数1:数据存储类型
 76         // 参数3:保存SqLite数据库文件的URL
 77         // 参数4:设置数据库选项
 78         let cacheDir = NSSearchPathForDirectoriesInDomains(.cachesDirectory, .userDomainMask, true).last!
 79         let path = (cacheDir as NSString).appendingPathComponent("ys.db")
 80         let dict = [NSMigratePersistentStoresAutomaticallyOption:true,
 81                     NSInferMappingModelAutomaticallyOption:true]
 82         
 83         let persistentStore = try? psc.addPersistentStore(ofType: NSSQLiteStoreType, configurationName: nil, at: URL(fileURLWithPath: path), options: dict)
 84         
 85         if persistentStore != nil{
 86             // 给管理上下文指定存储调度器
 87             mocObj?.persistentStoreCoordinator = psc
 88         }
 89         else{
 90             print("打开/新建/修改数据库出错")
 91             mocObj = nil
 92         }
 93         
 94         objc_sync_exit(self)
 95         
 96         return mocObj
 97     }()
 98     
 99     // 保存上下文
100     func saveContext () {
101         if let context = moc{
102             // 事务:可以保存多个数据,不一定每次数据发生变化都需要保存,可以一次性保存
103             if context.hasChanges {
104                 do {
105                     try context.save()
106                 } catch {
107                     let nserror = error as NSError
108                     print("保存数据出错:\(nserror)")
109                 }
110             }
111         }
112     }
113 }

 

以上是关于CoreDataManager-Swift版-兼容iOS10以前的版本的主要内容,如果未能解决你的问题,请参考以下文章

PDF预览完整解决方案及各种兼容(VUE版)

box-flex兼容写法

开放搜索开源兼容版,支持Elasticsearch做搜索召回引擎

jq双日历--最终版(功能兼容IE5,样式兼容IE6)

腾讯云TDSQL MySQL版 - 开发指南兼容性

XAMPP 的 Linux 版 (x86 兼容处理器版)安装配置使用详细介绍,教你建好一个LAMPP站!