gpt4 book ai didi

objective-c - 需要关于哪个选项可以有效地在 iPad 上存储数据的建议

转载 作者:行者123 更新时间:2023-11-28 19:21:26 25 4
gpt4 key购买 nike

这是我第一次为客户做一个大项目。所以我不确定如何解决这个问题。然而,我提出了两种不同的想法,但我需要专业人士的意见,看看哪一种更好:)

情况:

有一个应用程序运行在不同客户端的 iPad 上。应用程序数据使用巨大的 XML 文件存储。该 XML 文件由服务器在所有客户端之间共享。所以服务器有一个集中的副本,每个客户端都有自己的副本。一旦客户端更改了他们的 XML 副本,他们就会更新服务器副本,而其他客户端会通过更新的服务器副本来更新他们的副本。

现在一次只有一个客户端可以进行更改,为了解决这个问题,我有一个逻辑,在客户端开始编辑 XML 之前,他们需要从服务器获得所有权,而服务器一次只允许一个客户端进行编辑。

视觉呈现:

enter image description here


现在在客户端,我必须考虑一种逻辑,通过它我将更新我的客户端副本并将其上传到服务器。有两种选择,

选项 1:

在选项 1 中,我可以使用 GDataXML 解析器直接操作 XML 文件并将该副本上传到服务器。为了持久化,我可以将客户端副本保存在我 iPad 上的文档目录中。

enter image description here

选项 2:

在选项 2 中,我可以读取 XML 文件为本地存储创建一个 CoreData 表示。每当我更新核心数据中的数据时,我也会更改 XML 文件,而不是将该文件上传到服务器上。双重工作,但我想更好的坚持。

enter image description here


现在哪个更稳健和可取?我个人打算做选项 2,因为它看起来更可靠,因为我将应用程序数据持久化在核心数据中。但选项 1 似乎更容易工作,但我不知道如何保持良好的持久性。

抱歉,问题很长,

感谢您提供的任何输入。

最佳答案

有许多因素会影响选择第二个选项而不是第一个选项。

  • XML 文件有多大?如果您需要处理非常大的文档,您可能需要逐步将 XML (SAX) 解析为核心数据。这将允许您访问文档的内容,而无需一次将其全部加载到内存中。

  • 您是否需要在数据中运行复杂查询?如果是这样,您最好使用核心数据提取谓词,而不是 xpath 或 XSL。

  • 您已经在使用核心数据了吗?根据 XML 数据的结构,将数据导入现有的持久性存储区总体上可能更简单。

否则,您可能需要解析整个文档并遍历生成的树或使用 xpath 进行查询。

关于objective-c - 需要关于哪个选项可以有效地在 iPad 上存储数据的建议,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8644544/

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