- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有 3 个 MOC。
它们是父子关系。
现在,当我从后台下载数据时,我需要在主线程上禁用 undomanager,这样它们就不会撤消 - 这可能是用户正在同时编辑某些内容的情况。
现在的问题是这是否正确。我在后台更新线程中有该代码
//create child background context which is child of 1. MainThread
NSManagedObjectContext* context = [[AppManager sharedAppManager] createChildManagedObjectContext];
//I'M DOING ALL CHANGES ON DATA HERE
[context.parentContext.undoManager disableUndoRegistration]; //disable undo on main thread
[context save:nil]; //save changes to background thread
[context.parentContext save:nil]; //save changes to main thread
[context.parentContext processPendingChanges]; //process changes on main thread
[context.parentContext.parentContext save:nil]; //save data to disc on 3. save-thread
[context.parentContext.undoManager enableUndoRegistration]; //enable undo again
block 看起来像这样:
[context.parentContext performBlockAndWait:^{
[context.parentContext.undoManager disableUndoRegistration];
[context performBlockAndWait:^{
[context save:nil];
}];
[context.parentContext save:nil];
[context.parentContext processPendingChanges];
[context.parentContext performBlockAndWait:^{
[context.parentContext.parentContext save:nil];
}];
[context.parentContext.undoManager enableUndoRegistration];
}];
我问是因为偶尔我会遇到一些不一致的崩溃,而我真的找不到原因。
最佳答案
首先,对发布的代码进行一些基本观察。
您应该只在绝对必要时才使用 performBlockAndWait
...这几乎从不。
您在子上下文中调用 performBlockAndWait
,而在父上下文中调用 performBlockAndWait
。你不应该永远那样做。
使用 performBlockAndWait
在具有专利上下文的上下文中调用 save:
几乎可以保证不会按照您的想法行事。它所做的只是保存到父上下文。
您在同一上下文中的 performBlockAndWait
中调用 performBlockAndWait
。这没什么问题,因为该调用是可重入的。但是,这是另一个线索,表明您的 CD 堆栈管理存在问题。
现在,一些可能有帮助的建议。
在您的情况下,我建议更改您的 MOC 层次结构。将专用队列 MOC 作为主队列 MOC 的父级。这允许您的数据库更改异步完成。那里没有错。请记住,您必须将 save:
调用级联到父级或安排一次保存,因为保存主 MOC 只会将其数据复制到堆栈上到父级上下文,而不会触及底层数据库.
但是,我会采用该背景 MOC 并将其作为主要 MOC 的子项删除。现在,您完全不必担心撤消管理器,您可以不用管它。
说到撤消管理器,我发现最好的撤消管理器是子上下文。我只想创建一个上下文,它是主上下文的子上下文,在其中进行所有更改。如果放弃更改,只需删除上下文。一切都被撤销了。您可以在该上下文中安装撤消管理器以进行增量撤消管理。
现在,如何处理正在执行某种类型的异步更新(可能来自某些 Web 服务)的后台上下文。我建议:
将其父级设置为与主 MOC 相同。您将需要刷新主 MOC 以更改父级。这样做的缺点是,对数据库的任何更新都是通过同一个父 MOC 同步的,为主 MOC 留下更多等待获取的机会。
将其直接连接到持久存储协调器,并使用通知合并更改。
最后,重新审视您的设计,看看您是否可以使用异步调用。您真的应该能够避免调用 performBlock
,并且只在极少数情况下调用 performBlockAndWait
。
关于ios - UndoManager 和多个 MOC,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21781563/
我创建 temporaryContext 如下所示。它会包含未保存的更改还是仅包含来自 Utility.managedObjectContext() 的已保存更改? let temporaryCont
我在 CoreData 和父子 MOC 上遇到了这个问题:当向子 MOC 添加对象、保存它们并保存父 MOC 时,所有对象的属性都会重置为默认值。 我在这里粘贴了两个 MOC 的日志,具体是这些日志中
自上周以来我遇到了一个大问题,但我找不到任何可行的解决方案。 当我编译 Qwt 6.1.2(然后尝试使用 6.1.3)时 Windows 7 32bits mingw32控制台,编译序列后,我收到以下
我遇到了一个我无法理解的NSObjectInaccessibleException: *** Terminating app due to uncaught exception 'NSObjectI
想象一下两个托管对象上下文,moc A 和 moc B,它们填充了相同的对象集并共享相同的持久存储协调器。现在,我从 moc A 中删除一个对象并保存上下文。它还会存在于 moc B 中吗? 我测试了
直到现在,我一直对主线程使用“main moc”,初始化如下: [[NSManagedObjectContext alloc] init]; 然后我有 NSOperation 子类,它们有自己的 mo
假设我有一个显示 MOC,用于显示从 Web 服务获取的地址簿联系人。在应用程序的其他地方,我有一个搜索功能,可以根据用户输入的查询搜索 Web 服务,我获取这些对象并将其存储在暂存器 MOC 中,这
我想使用 Q_CLASSINFO 宏存储一些类信息。但是我想将它包装在我自己的宏中,例如: #define DB_TABLE( TABLE ) \ Q_CLASSINFO( "db_table
我无法使用已连接到正确插槽的按钮。 这里是 infoPage.cpp 文件: #include "infoPage.h" InfoPage::InfoPage(QWidget *parent)
我在编译项目时遇到了这个非常奇怪的问题。MOC 似乎正在向被 moc'ed 的类名添加一个命名空间,尽管它在文件/类中的任何地方都没有提到。 然而,命名空间存在于我使用的库中,但它隐藏在头文件中很远的
我必须从 Qt 命令提示符运行以下命令:qmake -project 然后是 make,这会为我提供带有 Moc 文件的调试文件夹。 奇怪的是,这是我的 PC 生成 moc_.cpp 文件的唯一方式。
我希望主队列中的每个实体都有一个 moc,这样用户就可以同时修改多个实体。 假设有 2 个实体:“包”和“类别”,一个包可以有多个类别。因此,当用户在选择类别时修改/创建 Bag 中的项目时,用户也可
我正在尝试构建qteSTLib/tutorial1示例,但是运行nmake时未生成testqstring.moc文件(我在Windows XP SP3上运行Qt 4.5.2)。 我将testqstri
我正在开发一个使用 cmake 的基于 Qt 的项目。我所有生成的 moc 文件都被命名为 *.moc ,但我有一些文件,它们生成的 moc 文件的名称为 moc_*.cpp ,不是 *.moc .为
我有 1 个 parent 2 个 child 的 moc 情况。其中 1 个子级是主界面 moc,另一个是用于在云上同步更改的专用队列。 我遇到过这样的情况:私有(private)云同步子模块保存更
我正在使用 QT Creator 1.3.1 并尝试编译,但出现此错误... 请帮我摆脱它 mingw32-make[1]: Leaving directory `C:/Documents and S
我正在尝试将 ovpn3 的 ovpncli 示例转换为派生自 QObject 的类。我无法将源文件转换为单独的接口(interface) (.h) 和实现 (.cpp) 文件。为了让 MOC 满意,
我的实体上有类别,允许我将 JSON 解析为实体: - (id) populateFromJson: (NSDictionary *) json { ... } 然后使用 MagicalReco
我目前正在使用 Qt (4.7) 编写一个小型应用程序。我使用嵌套的命名空间,比如 namespace app { namespace core { class CoreCla
我正在编写一个项目。尝试进行静态构建后,我开始出现错误。我做了一些更改,我不记得了。但是,我确信如果可以清除这个 stub ,那么主项目也可以被清除。 这是头文件。 #ifndef MYLABEL_H
我是一名优秀的程序员,十分优秀!