这是我第一次为客户做一个大项目。所以我不确定如何解决这个问题。然而,我提出了两种不同的想法,但我需要专业人士的意见,看看哪一种更好:)
情况:
有一个应用程序运行在不同客户端的 iPad 上。应用程序数据使用巨大的 XML 文件存储。该 XML 文件由服务器在所有客户端之间共享。所以服务器有一个集中的副本,每个客户端都有自己的副本。一旦客户端更改了他们的 XML 副本,他们就会更新服务器副本,而其他客户端会通过更新的服务器副本来更新他们的副本。
现在一次只有一个客户端可以进行更改,为了解决这个问题,我有一个逻辑,在客户端开始编辑 XML 之前,他们需要从服务器获得所有权,而服务器一次只允许一个客户端进行编辑。
视觉呈现:
现在在客户端,我必须考虑一种逻辑,通过它我将更新我的客户端副本并将其上传到服务器。有两种选择,
选项 1:
在选项 1 中,我可以使用 GDataXML 解析器直接操作 XML 文件并将该副本上传到服务器。为了持久化,我可以将客户端副本保存在我 iPad 上的文档目录中。
选项 2:
在选项 2 中,我可以读取 XML 文件为本地存储创建一个 CoreData 表示。每当我更新核心数据中的数据时,我也会更改 XML 文件,而不是将该文件上传到服务器上。双重工作,但我想更好的坚持。
现在哪个更稳健和可取?我个人打算做选项 2,因为它看起来更可靠,因为我将应用程序数据持久化在核心数据中。但选项 1 似乎更容易工作,但我不知道如何保持良好的持久性。
抱歉,问题很长,
感谢您提供的任何输入。
最佳答案
有许多因素会影响选择第二个选项而不是第一个选项。
XML 文件有多大?如果您需要处理非常大的文档,您可能需要逐步将 XML (SAX) 解析为核心数据。这将允许您访问文档的内容,而无需一次将其全部加载到内存中。
您是否需要在数据中运行复杂查询?如果是这样,您最好使用核心数据提取谓词,而不是 xpath 或 XSL。
您已经在使用核心数据了吗?根据 XML 数据的结构,将数据导入现有的持久性存储区总体上可能更简单。
否则,您可能需要解析整个文档并遍历生成的树或使用 xpath 进行查询。
关于objective-c - 需要关于哪个选项可以有效地在 iPad 上存储数据的建议,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8644544/