iOS的文件分类、存放路径及文件属性

关键数据

内容:用户创建的数据文件,无法在删除后自动重新创建,且会

路径:主目录/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,                                   //是扩展属性名字,是一个数组,每个扩展属性以结束 例如:user.name1system.name1user.name2

                           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);                                       //标识

原文地址:https://www.cnblogs.com/fanjing/p/4551589.html