我什么时候应该使用iOS中的各种存储机制?
我认为这已经涵盖了,但我的搜索没有任何相关性。
我知道有NSUserDefaults,核心数据,对象归档,原始SQLite,plist,当然还有Web服务器存储。 对于初学者来说,不清楚和有些模糊的是何时使用这些各种工具。
Web服务器与核心数据的使用是显而易见的,但是NSUserDefaults和plists呢? 核心数据与对象归档? 用例的简单细分将真正帮助我理解为什么在iOS中有如此多的存储选项。
我尝试编写一个快速简单的常见用例列表,因为正如@rmaddy所说,这个答案可以填写一个书的章节:
-
NSUserDefaults
:存储简单的用户首选项,没有太复杂或安全。 如果您的应用具有包含几个开关的设置页面,则可以在此处保存数据。 -
Keychain
(请参阅SSKeychain以获得更好的包装):用于存储敏感数据,如凭据。 -
PLists
:用于存储更大的结构化数据(但不是很大):它是一种非常灵活的格式,可以在很多场景中使用。 一些例子是:- 用户生成的内容存储:一个简单的Geopoint列表,将由地图或列表显示。
- 为您的应用提供简单的初始数据:在这种情况下,plist将包含在NSBundle中,而不是由用户生成并由用户数据填充。
- 将应用程序的特定模块所需的数据与其他数据分开。 例如,构建逐步启动教程所需的数据,其中每个步骤与其他步骤类似,但只需要不同的数据。 对这些数据进行硬编码可以轻松填充您的代码,因此您可以成为更好的开发人员并使用plist来存储数据并从中读取数据。
- 您正在编写可以由使用它的开发人员以某种方式配置的库或框架。
-
Object archiving
对于序列化更复杂的对象(可能包含二进制数据)非常有用,这些对象不能(或者您不希望)映射到更简单的结构(如plist)上。 -
Core Data
function强大,可以由不同的持久存储支持(SQLite只是其中之一,但您也可以选择XML文件,或者您甚至可以编写自己的格式!),并提供元素之间的关系。 它很复杂,并提供许多对开发有用的function,如KVO和上下文。 您应该将它用于许多相关记录的大型数据集,这些记录可以由用户生成或由服务器提供。 -
当您需要真正,快速地访问关系数据源(Core Data引入一些开销),或者如果您需要跨多个平台支持相同的SQLite格式时,
Raw SQLite
非常有用(您应该永远不要使用CoreData内部SQLite:它使用它自己的格式,所以你不能只是“导入”CoreData中的现有SQLite)。 例如,对于我工作的项目,web服务为我提供了一些大型SQLite而不是jsons或xmls:这些SQLite中的一些被导入到CoreData(操作可能需要一段时间,具体取决于源大小),因为我需要所有它的function,而其他SQLite直接读取,以实现快速访问。 -
Webserver storage
应该是显而易见的:如果您需要将数据存储到服务器,那是因为该设备不应该是该数据的唯一所有者。 但是,如果你只需要在不同的iOS设备上同步相同的应用程序(甚至是Mac的移植版本的应用程序),你也可以看看iCloud存储。