博客
关于我
iOS基础——数据存储之沙盒机制、Plist、Perference、归档、反归档
阅读量:717 次
发布时间:2019-03-21

本文共 3362 字,大约阅读时间需要 11 分钟。

iOS基础数据存储之沙盒机制、plist、perference归档反归档

一、沙盒机制

沙盒机制(SandBox)是iOS系统中的一个关键安全机制。它规定每个应用程序只能在自己专用的沙盒内存储和访问文件,无法跨越沙盒访问其他应用程序的内容。这种机制确保了应用程序的安全性和数据的孤立性。

沙盒机制的特点

  • 每个应用程序都有自己的沙盒,互不干扰
  • 应用程序无法随意访问其他沙盒的内容
  • 外部数据交流必须经过权限认证
  • 沙盒目录结构

    在沙盒中,主要包括以下几个目录:

    • Documents:保存需要持久化的应用数据,备份到iTunes会清理
    • tmp:存储临时性质的应用数据,自动清理,备份不会同步
    • Library/Caches:存储需要持久化但不重要的应用数据,不备份
    • Library/Preference:存储应用偏好设置,系统管理,备份时会同步

    获取沙盒路径

  • 获取主目录:

    NSString *path = NSHomeDirectory();
  • 获取应用程序的路径:

    NSString *bundlePath = [NSBundle mainBundle].bundlePath;
  • 获取Document目录:

    NSString *documentPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, NO) lastObject];

    改动后面的NOYES可以看到不同的路径表现

  • 获取Caches目录:

    NSString *cache = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, NO) lastObject];
  • 获取Temporary目录:

    NSString *tem = NSTemporaryDirectory();
  • 二、Plist

    Plist文件是iOS中常用的数据存储格式,起到类似数据库的作用,但不支持对象存储。主要用途包括保存用户设置和必要的应用数据。

    Plist操作示例

    • 写入Plist文件:
      NSString *savePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"data.plist"];NSArray *arr = [NSArray arrayWithObjects:@"hensen",@"java", nil];[arr writeToFile:savePath atomically:YES];
    • 读取Plist文件:
      NSString *savePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"data.plist";NSArray *getArr = [NSArray arrayWithContentsOfFile:savePath];NSString *myName = getArr[0];NSString *myLaugage = getArr[1];

    三、Perference

    Perference(偏好设置)用于存储应用的用户偏好配置,通常使用NSUserDefaults进行管理。该目录由系统管理,类似Keychain,需谨慎对待。

    Perference操作示例

    • 设置偏好:
      NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];[defaults setInteger:18 forKey:@"age"];[defaults setObject:@"hensen" forKey:@"name"];[defaults synchronize];
    • 获取偏好:
      NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];NSInteger *age = [defaults integerForKey:@"age"];NSString *name = [defaults objectForKey:@"name"];

    四、归档

    归档和反归档通过NSCoding协议实现对象的序列化和反序列化,弥补了Plist和Perference存储对象的短板。

    归档准备工作

  • 创建模型类:
    @interface PersonModel : NSObject@property (strong,nonatomic) NSString *name;@property (assign,nonatomic) NSInteger age;@end
  • 实现NSCoding协议:
    @interface PersonModel 
    @end
  • 归档实现

    -(nullable instancetype)initWithCoder:(NSCoder *)aDecoder{    if(self = [super init]){        self.name = [aDecoder decodeObjectForKey:@"name"];        self.age = [aDecoder decodeIntegerForKey:@"age"];    }    return self;}

    示例

    NSString *filePath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];NSString *fileName = [filePath stringByAppendingPathComponent:@"con.plist"];PersonModel *model = [[PersonModel alloc] init];model.name = @"hensen";model.age = 18;[NSKeyedArchiver archiveRootObject:model toFile:fileName];

    ##Five 反归档反归档即解包操作,核心是使用NSCoding协议恢复模型对象。

    反归档实现

    -(void)encodeWithCoder:(NSCoder *)aCoder{    [aCoder encodeObject:self.name forKey:@"name"];    [aCoder encodeInteger:self.age forKey:@"age"];}

    示例

    NSString *filePath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];NSString *fileName = [filePath stringByAppendingPathComponent:@"con.plist"]; PersonModel *person = [NSKeyedUnarchiver unarchiveObjectWithFile:fileName]; NSLog(@"name:%@,age:%ld", person.name, (long)person.age);

    通过合理运用沙盒机制、Plist、Perference、归档和反归档,可以有效管理iOS应用中的数据存储需求。尽管理论知识无误,但实际开发中建议根据具体项目需求灵活调整。

    转载地址:http://oevrz.baihongyu.com/

    你可能感兴趣的文章
    MySQL5.7.37windows解压版的安装使用
    查看>>
    mysql5.7免费下载地址
    查看>>
    mysql5.7命令总结
    查看>>
    mysql5.7安装
    查看>>
    mysql5.7性能调优my.ini
    查看>>
    MySQL5.7新增Performance Schema表
    查看>>
    Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
    查看>>
    Webpack 之 basic chunk graph
    查看>>
    Mysql5.7版本单机版my.cnf配置文件
    查看>>
    mysql5.7的安装和Navicat的安装
    查看>>
    mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
    查看>>
    Mysql8 数据库安装及主从配置 | Spring Cloud 2
    查看>>
    mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
    查看>>
    MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
    查看>>
    MYSQL8.0以上忘记root密码
    查看>>
    Mysql8.0以上重置初始密码的方法
    查看>>
    mysql8.0新特性-自增变量的持久化
    查看>>
    Mysql8.0注意url变更写法
    查看>>
    Mysql8.0的特性
    查看>>
    MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    查看>>