关键数据
内容:用户创建的数据文件,无法在删除后自动重新创建,且会
路径:主目录/Documents
属性:不要设置"不备份"
管理:iOS系统即时遇到存储空间不足的情况下,也不会清除,同时会备份到iTunes或iCloud中
缓存数据
内容:可用于离线环境,可被重复下载重复生成,即时在离线时缺失,应用本身也可以正常运行
路径:主目录/Library/Caches
属性:默认
管理:在存储空间不足的情况下,会清空, 并且不会被自动备份到iTunes和iCloud中
临时数据
内容:应用运行时,为完成某个内部操作临时生成的文件
路径:主目录/tmp
属性:默认
管理:随时可能被iOS系统清除,且不会自动备份到iTunes和iCloud,尽量在文件不再使用时,应用自己情况,避免对用户设备空间的浪费
离线数据
内容:与缓存数据类似,可以被重新下载和重建,但是用户往往希望在离线时数据依然能够托托地存在着
目录:主目录/Documents 或 主目录/Library/自定义的文件夹
属性:放于Documents下不需设置,放在自定义文件夹中需设置"不备份"
管理:与关键数据类似,即时在存储空间不足的情况下也不会清楚,应用自己应该清除已经不再使用的文件,以免浪费用户设备空间
从iOS5.0.1引入的设置不要备份文件(文件夹也适用)的扩展属性
1 #include <sys/xattr.h>
2 - (BOOL)addSkipBackupAttributeToItemAtURL:(NSURL *)URL
3 {
4 const char* filePath = [[URL path] fileSystemRepresentation];
5
6 const char* attrName = "com.apple.MobileBackup";
7 u_int8_t attrValue = 1;
8
9 int result = setxattr(filePath, attrName, &attrValue, sizeof(attrValue), 0, 0);
10 return result == 0;
11 }
1.列出相应路径的扩展属性
Ssize_t listxattr(const char *path , //路径
char *list, //是扩展属性名字,是一个数组,每个扩展属性以\0结束 例如:user.name1\0system.name1\0user.name2\0
size_t size); //分配缓存的大小
返回的是扩展属性的大小 包括/0;
2.列出扩展属性所对应的值
ssize_t getxattr(const char *path, //路径
const char *name, //扩展属性名字
void *value, //扩展属性所对应的值
size_t size); //扩展属性的长度
3.设置扩展属性
setxattr(path, //路径
key, //扩展属性的名字
value, // 扩展属性的值
size, //扩展属性的长度
flags); //标识