标签:key sea 介绍 man 下载 系统 举例 获取 服务
http://blog.csdn.net/jinnchang/article/details/44828189
1、沙盒机制介绍
iOS 中的沙盒机制(SandBox)是一种安全体系。
每个 iOS 应用程序都有一个单独的文件系统(存储空间),而且只能在对应的文件系统中进行操作,此区域被称为沙盒。所有的非代码文件都要保存在此,例如属性文件 plist、文本文件、图像、图标、媒体资源等。
2、沙盒目录结构
通常情况下,每个沙盒包含以下目录及文件:
- /AppName.app 应用程序的程序包目录。由于应用程序必须经过签名,所以不能在运行时对这个目录中的内容进行修改,否则会导致应用程序无法启动。
- /Documents/ 保存应用程序的重要数据文件和用户数据文件等。iTunes 同步时会备份该目录。
- /Library/Caches 保存应用程序使用时产生的支持文件和缓存文件,还有日志文件最好也放在这个目录。iTunes 同步时不会备份该目录。
- /Library/Preferences 保存应用程序的偏好设置文件(使用 NSUserDefaults 类设置时创建,不应该手动创建)。
- /tmp/ 保存应用运行时所需要的临时数据,iphone 重启时,会清除该目录下所有文件。
目录结构如下图所示:
补充1:对于上述描述可以这样举例理解,一个记事本应用,用户写的东西需要保存起来,这些东西是用户自行生成的,则需要放在 Documents 目录里。一个新闻应用,如果需要从服务器下载东西展示给用户看,下载的东西就放在 Library/Caches 目录里。苹果审核对这个要求很严格,主要原因是 iCloud 的同步问题。
补充2:如果想知道真机或者模拟器 App 沙盒路径,可通过在项目中执行下述代码打印获取:
- NSString *homeDirectoryPath = NSHomeDirectory();
3、获取沙盒中各目录路径
- NSString *homeDirectoryPath = NSHomeDirectory();
-
- NSString *appDirectoryPath = [NSSearchPathForDirectoriesInDomains(NSApplicationDirectory, NSUserDomainMask, YES) objectAtIndex:0];
-
- NSString *documentDirectoryPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
-
- NSString *cachesDirectoryPath = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) objectAtIndex:0];
-
- NSString *tmpDirectoryPath = NSTemporaryDirectory();
4、NSFileManager
使用 FileManager 可以对沙盒中的目录、文件进行操作。通过如下方式可以获取 NSFileManager 的单例:
- [NSFileManager defaultManager]
5、程序包(NSBundle)
iOS 应用都是通过 bundle 进行封装的,可以狭隘地将 bundle 理解为上述沙盒中的 AppName.app 文件。在 Finder 中,会把 bundle 当做一个文件显示从而防止用户误操作导致程序文件损坏,但其实内部是一个目录,包含了图像、媒体资源、编译好的代码、nib 文件等,这个目录称为 main bundle。
Cocaoa 提供了 NSBundle 类封装了 bundle 操作。
- NSBundle *mainBundle = NSBundle.mainBundle;
-
- NSString *filePath = [mainBundle pathForResource:@"logo" ofType:@"png"];
iOS 文件操作:沙盒(SandBox)、文件操作(FileManager)、程序包(NSBundle)
标签:key sea 介绍 man 下载 系统 举例 获取 服务
原文地址:http://www.cnblogs.com/feng9exe/p/7199675.html