一 An iOS app operating within its own sandbox directory
在自己的沙盒目录下运行的iOS应用程序
An app is generally prohibited from accessing or creating files outside its container directories. One exception to this rule is when an app uses public system interfaces to access things such as the user’s contacts or music. In those cases, the system frameworks use helper apps to handle any file-related operations needed to read from or modify the appropriate data stores.
应用程序通常不允许在它的容器目录之外访问或创建文件。一个例外是当应用程序使用公共系统接口去访问例如用户的联系人或音乐。在这些场景,系统框架使用开发者帮助文档去处理需要从适当的数据存储读取或修改的任何文件相关的操作。
二 Where You Should Put Your App’s Files
To prevent the syncing and backup processes on iOS devices from taking a long time, be selective about where you place files. Apps that store large files can slow down the process of backing up to iTunes or iCloud. These apps can also consume a large amount of a user's available storage, which may encourage the user to delete the app or disable backup of that app's data to iCloud. With this in mind, you should store app data according to the following guidelines:
为了防止在iOS设备同步和备份使用很长的时间,你的文件存储位置是可以被选择的。存储大文件的应用程序会减慢备份到iTunes或iCloud的过程,这些应用也会消耗大量用户可用空间。这些都会促使用户删除应用或者不再备份应用的数据到iCloud。基于此,你应该按照如下指南进行存储应用数据。
Put user data in Documents/. User data generally includes any files you might want to expose to the user—anything you might want the user to create, import, delete or edit. For a drawing app, user data includes any graphic files the user might create. For a text editor, it includes the text files. Video and audio apps may even include files that the user has downloaded to watch or listen to later.
将用户数据存放在Documents/. 路径。用户数据一般包括你可能想暴露给用户的任何文件,你可能想让用户创建、引入、删除或编辑的任何数据。对于一个绘制应用程序,用户数据包含用户可能创建的任何图表文件。对于一个文本编辑器,它包含一些文本文件。视频和音频类应用可能甚至包含用户已经下载后要观看或收听的文件。
Put app-created support files in the Library/Application support/ directory. In general, this directory includes files that the app uses to run but that should remain hidden from the user. This directory can also include data files, configuration files, templates and modified versions of resources loaded from the app bundle.
将应用创建的支持文件放在路径Library/Application support/ directory,一般而言,这个目录包含应用运行需要的但是对用户而言应该要隐藏的文件。该目录还可以包含从app bundle中加载的数据文件、配置文件、模板和修改版本的资源
Remember that files in Documents/ and Application Support/ are backed up by default. You can exclude files from the backup by calling -[NSURL setResourceValue:forKey:error:] using the NSURLIsExcludedFromBackupKey key. Any file that can be re-created or downloaded must be excluded from the backup. This is particularly important for large media files. If your application downloads video or audio files, make sure they are not included in the backup.
记得Documents/ and Application Support/目录下的文件默认会备份。通过使用NSURLIsExcludedFromBackupKey键调用-[NSURL setResourceValue:forKey:error:]可以从备份中排除文件。任何可以重新创建或下载的文件都必须排除在备份之外。这对于大型媒体文件来说尤其重要。如果你的应用下载视频或音频文件,确认他们不是包含在备份中。
Put temporary data in the tmp/ directory. Temporary data comprises any data that you do not need to persist for an extended period of time. Remember to delete those files when you are done with them so that they do not continue to consume space on the user’s device. The system will periodically purge these files when your app is not running; therefore, you cannot rely on these files persisting after your app terminates.
将临时文件存储在tmp/目录。临时数据包含你不需要长期使用的任何数据。记得去删除这些文件当你已经使用完了,因此他们不会继续占用用户设备的空间。当应用不再运行时系统将会定时清除这些文件;因此当应用终止时你不能依赖这些文件持久化
Put data cache files in the Library/Caches/ directory. Cache data can be used for any data that needs to persist longer than temporary data, but not as long as a support file. Generally speaking, the application does not require cache data to operate properly, but it can use cache data to improve performance. Examples of cache data include (but are not limited to) database cache files and transient, downloadable content. Note that the system may delete the Caches/ directory to free up disk space, so your app must be able to re-create or download these files as needed.
将数据缓存文件存储在Library/Caches/ 目录。缓存数据可以应用于任何需要比临时文件持久化的数据,但是没有支持文件更久。一般而言,应用不会要求缓存数据也能正确操作,但它可以使用缓存数据来提升性能。缓存数据的例子包含(但不限于)数据库缓存文件和临时的、可下载的内容。系统会删除Caches/目录清空磁盘空间,因此当需要这些文件的时候你的应用必须可以重新创建或下载。
三 总结
1、存储内容类型
/Documents一般会存储用户生成的内容,此目录应该只包含您可能希望向用户公开的文件
/Library/ 一般不会存储用户数据文件,此目录包含不希望向用户公开的任何文件
/tmp/ 一般会存储在应用程序启动期间不需要持久保存的临时文件,此目录会在应用不再运行时被清空
2、文件备份情况
/Documents这个目录的内容由iTunes和iCloud备份
/Library/ 这个目录的内容由iTunes和iCloud备份
/tmp/ 这个目录的内容没有iTunes或iCloud备份
四 目录说明
Table 1-1 lists some of the more important subdirectories inside the sandbox directory and describes their intended usage. This table also describes any additional access restrictions for each subdirectory and points out whether the directory’s contents are backed up by iTunes and iCloud.
表格1-1列出了一些在沙盒目录更重要的子目录并描述了它们的预期用途。这个表格也描述了对于每个子目录的任何额外访问限制,同时指出了目录内容是否从iTunes和iCloud中备份的。
Directory / Description
AppName.app
This is the app’s bundle. This directory contains the app and all of its resources.You cannot write to this directory. To prevent tampering, the bundle directory is signed at installation time. Writing to this directory changes the signature and prevents your app from launching. You can, however, gain read-only access to any resources stored in the apps bundle. For more information, see the Resource Programming Guide.The contents of this directory are not backed up by iTunes or iCloud. However, iTunes does perform an initial sync of any apps purchased from the App Store.
Documents/
Use this directory to store user-generated content. The contents of this directory can be made available to the user through file sharing; therefore, this directory should only contain files that you may wish to expose to the user.The contents of this directory are backed up by iTunes and iCloud.
Documents/Inbox
Use this directory to access files that your app was asked to open by outside entities. Specifically, the Mail program places email attachments associated with your app in this directory. Document interaction controllers may also place files in it.Your app can read and delete files in this directory but cannot create new files or write to existing files. If the user tries to edit a file in this directory, your app must silently move it out of the directory before making any changes.The contents of this directory are backed up by iTunes and iCloud.
Library/
This is the top-level directory for any files that are not user data files. You typically put files in one of several standard subdirectories. iOS apps commonly use the Application Support and Caches subdirectories; however, you can create custom subdirectories.Use the Library subdirectories for any files you don’t want exposed to the user. Your app should not use these directories for user data files.The contents of the Library directory (with the exception of the Caches subdirectory) are backed up by iTunes and iCloud.For additional information about the Library directory and its commonly used subdirectories, see The Library Directory Stores App-Specific Files.
tmp/
Use this directory to write temporary files that do not need to persist between launches of your app. Your app should remove files from this directory when they are no longer needed; however, the system may purge this directory when your app is not running.The contents of this directory are not backed up by iTunes or iCloud.
五 文档相关
文档参考 https://developer.apple.com
如对读书、测试感兴趣的小伙伴可关注如下WeChat:琦哥私房菜,小编会分享读书笔记和测试技术文章,希望同大家一起进步。