CoreData并发操作模式简介

iOS5.0中,苹果为CoreData的并发处理添加了两个内容。

一、首先介绍第一个内容:
CoreData框架中的NSManagedObjectContext类增加新的初始化方法:
initWithConcurrencyType:(NSManagedObjectContextConcurrencyType)ct;

1.参数方法介绍:
NSManagedObjectContextConcurrencyType一共有三种:
(1)NSPrivateQueueConcurrencyType:绑定一个后台线程。
(2)NSMainQueueConcurrencyType:绑定一个主线程
(3)NSConfinementConcurrencyType:此类型一般不用,这是为了兼容遗留旧代码用的。此类型不能执行performBlock。

2.ManagedObjectContext的performBlock和performBlockAndWait方法:

(1)performBlock方法:
在上下文队列中异步执行此block,塞入自动释放池,然后调用processPendingChanges方法。
- (void)performBlock:(void (^)())block;

(2)performBlockAndWait方法:
在上下文队列中同步执行此block,调用起来比较安全。
- (void)performBlockAndWait:(void (^)())block;

(3)processPendingChanges方法:
通常情况下上下文会在事件结束时同步改变到对象状态图。此方法会明确的触发此动作。
- (void)processPendingChanges; 

(4)save方法:
save保存到磁盘,调用save将自动调用processPendingChanges;

3.线程安全
(1)每一条线程只能有唯一的一个ManagedObjectContext的模式与此相对应,苹果的官方文档给出了两种解决并发问题的方案:
    <1>为每个线程创建单独的ManagedObjectContext,然后多个ManagedObjectContext共享一个独立的NSPersistentStoreCoordinator,这个是通常推荐使用的方式。
    <2>为每个线程创建单独的ManagedObjectContext和NSPersistentStoreCoordinator,这个方法在复杂、大并发的情况下使用,特别是需要在几个上下文中同步更改的场景,但是这个方法会增加内存使用量。
(2)NSManagedObjects不是线程安全的,但是NSManagedObjectIDs是线程安全的。
(3)如果在background保存,则需要通过core data Notification将changes同步到其他contexts。

二、嵌套的ManagedObjectContext

1.概述:
当子Context中做保存操作时,因为子context没有persistentStoreCoordinator,这个变化会首先推送给他的父context,这个操作将一直传递,直到找到没有父Context的RootContext为止,当rootContext收到这个消息的时候,rootContext自动合并了这次操作,并且做了最终的保存。所以子context查找时,同样也会首先从父context那里查找而不是直接与persistentStoreCoordinator交流。当使用这种结构时,不需要特别去监听NSManagedObjectContextObjectsDidChangeNotification 来合并异步操作到主线程,这也是这种结构的方便之处。

2.对于这种结构,有三种并发策略:

策略一:
这个策略可能并不是那么好,写在这里主要是为了与更好地备选方案进行对比。这个方案的组成部分:
(1)NSMainQueueConcurrencyType类型的Main Context,此上下文与persistentStoreCoordinator进行关联。
(2)NSPrivateQueueConcurrencyType类型的Background Context,Main Context作为它的上级Context。此Context用作数据插入和查询。

CoreData并发操作 - 米安格 - 米安格的博客   

策略二 :
此方案的组成部分:
(1)NSPrivateQueueConcurrencyType类型的Master Context,此上下文与persistentStoreCoordinator进行关联。
(2)NSMainQueueConcurrencyType类型的Main Context,作为Master Context的子Context。
(3)NSPrivateQueueConcurrencyType类型的Worker Context,此Context用作数据插入和查询。

同样使用嵌套ManagedObjectContext,但是使用PrivateQueue作为主Context。对于Worker Context作操作将会经由MainQueue Context 最终由MasterContext合并。这个方案的好处在于Worker Context都是临时工,不需要考虑他们的生命周期。另外的一个好处是,由于他们不能自动获取到来自父亲的更新,所以这个任务可以再未完成之前随时取消。

CoreData并发操作 - 米安格 - 米安格的博客

策略三 :
这个方案相对保守,没有使用嵌套Context这个新的特性。
此方案的组成部分:
(1)NSMainQueueConcurrencyType类型的Main Context,此上下文与persistentStoreCoordinator进行关联。
(2)NSPrivateQueueConcurrencyType类型的Background Context,此上下文也关联同一个persistentStoreCoordinator。

Main Context在主线程队列,Background Context在子线程队列。数据同步通过通知实现,每个Context都注册NSManagedObjectContextDidSaveNotification通知,并且在收到通知后调用另一个Context的mergeChangesFromContextDidSaveNotification方法。
CoreData并发操作 - 米安格 - 米安格的博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/500063.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Linux系统基础】(3)在Linux上部署运维监控Zabbix和Grafana

目录 运维监控Zabbix部署简介安装安装前准备 - Mysql安装Zabbix Server 和 Zabbix Agenta. 安装Zabbix yum库b. 安装Zabbix Server、前端、Agentc. 初始化Mysql数据库d. 为Zabbix Server配置数据库e. 配置Zabbix的PHP前端 配置zabbix 前端&#xff08;WEB UI&#xff09; 运维监…

HashMap源码解释

HashMap 前言: 本文的hashMap是基于jdk1.7的hashMap. 关于jdk1.8的hashMap在另一篇中,那里将会介绍与1.7的差异与优势 首先基础知识介绍: 1.HashMap的成员变量   int DEFAULT_INITIAL_CAPACITY 16&#xff1a;默认的初始容量为2 ^ 4   int MAXIMUM_CAPACITY 1 <<…

MagicRecord For IOS 简介

一、概述 MagicalRecord 灵感来自于简洁的Ruby语言中 Rails Active Record 查询方式. MagicalRecord 这个开源库的核心思想是: 1.清除 Core Data 相关的代码2.简洁的清除,简单的一行搜索记录的功能3.当然允许使用NSFetchRequest,当存在着复杂的搜索条件时 二、使用 1. 导入框架…

对象引用 String引用 基本类型引用 差别

最近遇到一个线上问题,原因是忽略的引用的一些语法,导致出错,现在记录一下: Testpublic void testList(){List<String> list new ArrayList<String>();list.add("1");list.add("2");list.add("3");List<String> list2 new …

ReactiveCocoa入门

概述 为什么要使用RAC&#xff1f;一个怪怪的东西&#xff0c;从Demo看也没有让代码变得更好、更短&#xff0c;相反还造成理解上的困难&#xff0c;真的有必要去学它么&#xff1f;相信这是大多数人在接触RAC时的想法。RAC不是单一功能的模块&#xff0c;它是一个Framework&am…

C++和Objective-C混编(官方文档翻译)

苹果的Objective-C编译器允许用户在同一个源文件里自由地混合使用C和Objective-C&#xff0c;混编后的语言叫Objective-C。有了它&#xff0c;你就可以在Objective-C应用程序中使用已有的C类库。 Build Setting中要设定编译文件类型设置&#xff0c;如下图&#xff1a;Objectiv…

Create groups 与 Create folder references的区别

选择了Create groups方式添加了一个文件&#xff0c;我们会发现被添加进来的文件&#xff0c;文件夹是黄色的。选择了 Create folder references方式添加进来的文件的文件夹是蓝色的。那么两种方式有什么区别呢&#xff1f; 1.使用Create groups 为任何新增加的文件夹创建组&a…

React Native新手引导

序言 本教程希望让您快速熟悉使用React Native来编写iOS和Android App的技巧。如果你希望知道React Native是什么以及为什么Facebook打造了它&#xff0c;可以读读这篇博文 我们这里假设你已经有了使用React编写Web应用程序的经验。如果还没有&#xff0c;建议你可以先从React官…

服务器启动报错:One or more listeners failed to start. Full details will be found in the ...

idea本地启动web项目时 报错如下: One or more listeners failed to start. Full details will be found in the appropriate container log file 我的解决方案: 增加一步,配置artifacts 具体如下: 这个地方选择自己本地的web项目文件夹 都配置完然后Apply下,这个都配置好…

React Native使用指南-使用链接库

并不是所有的APP都需要使用全部的原生功能&#xff0c;包含支持全部特性的代码会增大应用的体积。但我们仍然希望能让你简单地根据自己的需求添加需要的特性。 在这种思想下&#xff0c;我们把许多特性都发布成为互不相关的静态库。 大部分的库只需要拖进两个文件就可以使用了&…

React Native使用指南-植入原生应用

由于React并没有假设你其余部分的技术栈——它通常只作为MVC模型中的V存在——它也很容易嵌入到一个并非由React Native开发的应用当中。实际上&#xff0c;它可以和常见的许多工具结合&#xff0c;譬如CocoaPods。 需求 CocoaPods – gem install cocoapodsNode.js 安装 nvm&a…

RPC协议与Web Service

一、引入 我们每天都在使用浏览器来上网冲浪, 在查找自己需要的资源, HTTP协议自然是我们使用的最多的 一种, 我们尽情地享受着这种信息高速路的快感,却没有试图去了解我们是如何获得这些资源的? 它是一种什么样的设计理念? 我们也偶尔会使用 Gtalk来和自己的同事或者朋友来聊…

RestFull架构

1 什么是REST REST全称是Representational State Transfer&#xff0c;中文意思是表述性状态转移。 它首次出现在2000年Roy Fielding的博士论文中&#xff0c;Roy Fielding是 HTTP 规范的主要编写者之一。 他在论文中提到:“我这篇文章的写作目的&#xff0c;就是想在符合架构原…

controller中执行main方法报错NoClassDefFoundError: javax/servlet/http/HttpServletResponse

controller中执行main方法报了这个错:NoClassDefFoundError: javax/servlet/http/HttpServletResponse,如下图: NoClassDefFoundError: javax/servlet/http/HttpServletResponse NoClassDefFoundError: javax/servlet/http/HttpServletRequest同理 原因是本地没有引入servlet…

初探Backbone

Backbone简介 中文API&#xff1a;http://www.css88.com/doc/backbone/ 英文API&#xff1a;http://backbonejs.org/ Backbone是构建javascript应用程序的一个优秀的类库。他简洁、轻量级、功能实在。 backbone采用MVC模式&#xff0c;本身提供了模型、控制器和视图从而我们应用…

订单量的监控

要解决的问题 : 1.在电商项目中,如何准确的知道当前订单量是正常的 2.如何在订单量突变后快速感知 解决思路 : 实现一个关于订单量的监控系统,将历史数据与实时数据做对比,因为每天的订单量,基本都是一个相似的变化范围,比如凌晨4点的单量是一天中最少的,节假日的单量要小于工…

基于abtest思想的流量切换(nginx lua redis)

使用前提: 项目重构了,旧项目还在线上运行,新项目准备替换线上的旧项目 最终目标: 要实现实时切换新旧项目,保证如果新项目上线后有问题,可以立刻快速的将流量切回旧项目 方案: 关于abtest的基本原理本文不再多说,本文重点是实践&#xff0c;先看图 如上图所示,用户访问的…

JavaScript内部实现

前言 JavaScript 的核心 ECMAScript 描述了该语言的语法和基本对象&#xff1b; DOM 描述了处理网页内容的方法和接口&#xff1b; BOM 描述了与浏览器进行交互的方法和接口。 ECMAScript、DOM 和 BOM 尽管 ECMAScript 是一个重要的标准&#xff0c;但它并不是 JavaScript 唯一…

流式计算storm核心组件介绍以及入门案例---跟着就能在本地跑起来的storm项目

关于storm的基础,参照我这篇文章:流式计算storm 关于并发和并行,参照我这篇文章:并发和并行 关于storm的并行度解释,参照我这篇文章:storm的并行度解释 关于storm的流分组策略,参照我这篇文章:storm的流分组策略 关于storm的消息可靠机制,参照我这篇文章:storm的消息可靠机制 …

nginx使用gzip压缩文件---lz77算法---Haffman编码

为了提高页面的响应速度,可以从设置 nginx 的 gzip 和缓存这2方面入手,而为ttf,js,css等文件开启 gzip 和缓存能大大减少带宽的消耗. HTTP 的内容编码机制 Accept-Encoding 和 Content-Encoding 是 HTTP 中用来对[采用何种编码格式传输正文]进行协定的一对头部字段. 它的工作…