OGeek|极客世界-中国程序员成长平台

标题: ios - 在 iOS8 上将所有数据存储在 App Groups 的容器区域中是否有任何弱点? [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-13 10:15
标题: ios - 在 iOS8 上将所有数据存储在 App Groups 的容器区域中是否有任何弱点?

我正在考虑将所有数据存储在应用组的容器区域中,以创建支持 AppExtensions 的应用。

在 iOS8 上将 所有 数据存储在 App Groups 的容器区域中是否有任何弱点? 我应该在 App Group 的容器区域中存储有限的数据吗?

App Extension Programming Guide: Handling Common Scenarios



Best Answer-推荐答案


这当然取决于您的应用,但这是我的两分钱:

将您的所有信息存储在共享目录中完全是矫枉过正,听起来不像是出于任何合理的推理。如果您认为您的小部件需要您的应用所需的所有信息,那么您可能需要重新考虑小部件的复杂性。

您这样做是为了方便(将来您会头疼)而不是简单(通过单一责任隐藏复杂性)。需要注意的是,随着应用程序的增长和变得越来越复杂,您最终将花费更多的时间来促进应用程序容器内部的信息(例如 massive view controller)。你要争取的是单一的责任。相反,您现在需要一个对象来促进将两个应用程序的信息放入一个容器中。

共享容器也不同于应用沙盒,因为您需要担心协调读取和写入。这就是为什么通常最好继续使用 Core Data 或 NSUserDefaults(使用套件名称实例化)。如果您的应用程序存储图像和其他内容,那么您将陷入痛苦的世界。偶Apple推荐 User Defaults(因为这是他们给出的唯一示例)或 CoreData:

After you enable app groups, an app extension and its containing app can both use the NSUserDefaults API to share access to user preferences [...] To avoid data corruption, you must synchronize data accesses. Use Core Data, SQLite, or Posix locks to help coordinate data access in a shared container.

小部件的目的是提供您应用的即时概览。通过最小化小部件可以访问您的数据量,将减少许多令人头疼的问题,并使您的小部件更好地包含。请记住,强大的力量伴随着巨大的责任,如果您认为将所有信息存储在一个共享容器中,那么您需要承担很多责任......

示例

我最近完成了为新闻应用程序构建一个小部件,该小部件显示热门新闻故事以及个性化小部件显示的内容的能力。下面是数据持久性的基本分解,以提供您一个想法:

存储分割

小部件

应用

共享容器

当小部件被要求获取内容时,它会下载一个 JSON 文件,其中包含所有主题的热门故事。这个 JSON 被持久化到共享容器中。我们存储所有故事的原因是,如果用户更改了他们喜欢的主题,小部件可以在存储所有主题时简单地更新其选择。这还允许应用更新热门故事和小部件以立即反射(reflect)这一点。

然后,该小部件将提取与用户指定的主题标签匹配的 3 个热门故事。这些热门主题保留在共享的用户默认项中。自然有可能在用户选择主题之前打开小部件,在这种情况下小部件会自动选择前三个左右的主题。

TL;DR

一个比喻 - 如果一个 Widget 和一个 App 是工作场所的同事,那么 Shared Container 就像一台计算机。在同一台计算机上与某人整天、每一天的工作效率如何?

关于ios - 在 iOS8 上将所有数据存储在 App Groups 的容器区域中是否有任何弱点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28205758/






欢迎光临 OGeek|极客世界-中国程序员成长平台 (https://ogeek.cn/) Powered by Discuz! X3.4