gpt4 book ai didi

core-data - 如何处理 UIManagedDocument?

转载 作者:行者123 更新时间:2023-12-02 23:33:51 27 4
gpt4 key购买 nike

首先,我应该提到这是我在这个网站上的第一篇文章。我正在尝试自学 iOS 编程,在谷歌搜索答案时,我发现我经常被引导到这里。所以感谢所有在这里做出贡献的人。你已经帮了我很多了。

我一直在参加斯坦福大学 CS193P 类(class)并且喜欢它。但我现在陷入困境,不知道该转向哪里。

我的问题出在 UIManagedDocument 上。

我厌倦了制作一个简单的应用程序来测试我的新技能。这就是它的作用:

一个简单的会计应用程序,用于跟踪个人对筹款事件的捐款。

我有一个 UITabBar,每个选项卡上都允许您:1. 跟踪参与者(玩家)- 这将连接到地址簿并允许您添加他们或仅将他们保留在此应用程序中。2. 管理事件(Events) - 您可以添加、编辑或删除事件,然后将参与者添加到其中,然后能够添加他们在该事件中带来的内容(银行)。3. 设置。 - 我添加了一些按钮只是为了帮助我解决问题,包括一个清除所有数据的重置按钮和一个“虚拟数据”按钮。

我有三个 coreData 实体。玩家、赛事和银行都与另外两者有关系。

当我第一次尝试制作这个应用程序(iOS5 之前)时,我使用 appDelegate 创建我的 ManagedObjectContext 并将其传递给我的 viewControllers。那行得通。但现在我应该使用 UIManagedObjectDocument 而不是使用 AppDelegate。我相信我了解原理以及与 iCloud 的集成。 (我可能是错的)

使用类(class)中的示例以及我在网上可以找到的内容,我创建了一个帮助程序类,它将在我的 UINavigationControllers 中提供每个 ViewControllers 中的第一个 ManagedDocument。

+ (UIManagedDocument *)sharedManagedDocument
{
static UIManagedDocument *sharedDocument = nil;

NSURL *url = [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject];
url = [url URLByAppendingPathComponent:@"DefaultAppDatabase"];
// url is "<Documents Directory>/<DefaultAppDatabase>"

// Create the shared instance lazily upon the first request.
if (sharedDocument == nil) {
sharedDocument = [[UIManagedDocument alloc] initWithFileURL:url];
}

if (sharedDocument.fileURL != url) {
UIManagedDocument *newDocument = [[UIManagedDocument alloc] initWithFileURL:url];
sharedDocument = newDocument;
}

NSLog(@"SharedDocument: %@", sharedDocument);

return sharedDocument;
}

然后我让第一个 ViewController 打开文档并执行获取。

从那里我将选择的任何 NSManagedObject 通过 segue 传递给下一个 ViewController。

问题出在我添加或重置数据时。 (我假设如果我可以让它与“虚拟数据”按钮一起工作,我就可以让它在单个条目上工作)当我按下“重置”或“虚拟”按钮时,我的日志告诉我它是已推送,但在重新启动应用程序之前我看不到数据有任何变化。然后就完美的显示出来了。我的猜测是我没有正确保存文件或者我没有正确刷新 tableViews。我尝试使用 NSNotification 但没有深入研究,因为我无法让它响应任何内容。如果需要的话,我很乐意回到那条路。

这是我的保存方法...几乎只是从默认的 coreData appDelegate 复制而来。

- (void)saveContext
{
NSError *error = nil;
NSManagedObjectContext *managedObjectContext = self.appDatabase.managedObjectContext;
if (managedObjectContext != nil)
{
if ([managedObjectContext hasChanges] && ![managedObjectContext save:&error])
{
/*
Replace this implementation with code to handle the error appropriately.

abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
*/
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}
}

[self.appDatabase saveToURL:self.appDatabase.fileURL
forSaveOperation:UIDocumentSaveForOverwriting
completionHandler:^(BOOL success){
if(!success) NSLog(@"failed to save document %@", self.appDatabase.localizedName);
if(success) NSLog(@"Success: save document %@", self.appDatabase.localizedName);
}];

}

CS193P 的讲师 Paul 在作业 6 中建议使用辅助方法通过 block 传递 UIManagedDocument。我了解了 block 背后的理论,但还没有完全理解它们,所以我没有排除我的答案也可能在那里。

非常感谢您的帮助或为我指明了进行更多研究的正确方向。抱歉这篇文章太长了,我试图尽可能清楚地表达。

最佳答案

我对整件事想得太多了。艾伦在这篇文章中完美地提出了我的问题:

How do I create a global UIManagedDocument instance per document-on-disk shared by my whole application using blocks?

问题和答案澄清了一切。

谢谢

关于core-data - 如何处理 UIManagedDocument?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9083088/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com