iOS存储方式之归档
介绍
iOS有几种存储数据在本地的方式,比如属性表plist、coredata的数据库存储等等,这里讲解归档这种存储方式。
归档是一种翻译的名字,原名叫 Archiver ,可以理解成将数据以序列化的方式存储在本地,像是将文件放在文件夹中一样,进行资料的归档存放。其实相关的类名为 NSKeyedArchiver ,keyed 在这里应该是对归档的数据赋上了键的意思,就想给文件存档时要按照有文件名。
与之相对的有一个类叫 NSKeyedUnarchiver ,顾名思义就是反归档了,也可以叫解档,可以将之前归档的数据恢复成原始数据。
其实我所理解的这个过程很像压缩与解压,在存储多对象时我们待会也会看到确实有一个 encode 和 decode 的过程,方法名就是这个,所以为了便于理解也可以想象成将数据压缩成一个压缩包后存储在本地,要恢复数据时再解压就可以了。
本文举两个归档的例子,一个是简单的对单个对象进行归档,另一个是对多个对象统一归档到一起。
归档单个对象
先直接上代码:
NSString *homeDirectory = NSHomeDirectory();// 根目录
NSString *demoPath = [homeDirectory stringByAppendingPathComponent:@"demo.archiver"];// 添加存储的文件名
BOOL flag = [NSKeyedArchiver archiveRootObject:@"Cloudox" toFile:demoPath];// 归档一个字符串
if (flag) NSLog(@"归档成功");
NSLog(@"解档后为:%@", [NSKeyedUnarchiver unarchiveObjectWithFile:demoPath]);
要归档数据进行存储,当然要有存储的位置,所以首先获取设备的目录并且建立一个要存储归档数据的目录,注意后缀名要是 .archiver 。
随后的 archiveRootObject: toFile: 方法就是将一个对象归档并存储到文件位置了,很简单明了,这个方法会返回一个布尔值,表示是否归档存储成功了。
解档使用的是 unarchiveObjectWithFile: 方法,从数据的存储路径获取归档文件进行解档,就得到了我们存储的原始数据了。
运行后的结果如图:
归档多个对象
还是先上代码然后对着看:
NSString *name = @"Cloudox";
NSInteger age = 24;
//路径
NSString *multiPath = [homeDirectory stringByAppendingPathComponent:@"multi.archiver"];
//存储多个对象的容器
NSMutableData *multiData = [[NSMutableData alloc] init];
NSKeyedArchiver *multiArchiver = [[NSKeyedArchiver alloc] initForWritingWithMutableData:multiData];
[multiArchiver encodeObject:name forKey:@"name"];
[multiArchiver encodeInteger:age forKey:@"age"];
[multiArchiver finishEncoding];// 结束对多个对象的归档
[multiData writeToFile:multiPath atomically:YES];
// 解档
//存储解档后多个对象的容器
NSMutableData *unMultiData = [[NSMutableData alloc] initWithContentsOfFile:multiPath];
NSKeyedUnarchiver *multiUnarchiver = [[NSKeyedUnarchiver alloc] initForReadingWithData:unMultiData];
NSString *unName = [multiUnarchiver decodeObjectForKey:@"name"];
NSInteger unAge = [multiUnarchiver decodeIntegerForKey:@"age"];
[multiUnarchiver finishDecoding];// 结束对多个对象的解档
NSLog(@"多对象解档后为:%@的年龄为%ld", unName, unAge);
要归档多个对象,除了存储路径外,我们还要有一个 NSMutableData 对象来作为容器存放多个对象,也就是说我们实际归档的是这个 NSMutableData 对象。代码中使用了 encodeObject: forKey: 和 encodeInteger: forKey: 方法来分别压缩对象数据和整型数据,这里不同类型的数据是有不同方法的,当然不同的数据是要赋给不同的键的,之后要根据键来获取目标数据,全部要固定的对象都压缩后就可以 finishEncoding 了。
解档时也需要一个 NSMutableData 来作为解档后的数据容器,然后对其中的数据进行解码,这里就用到了归档时所赋的键,解码结束后同样要 finishDecoding ,便得到了需要的数据。
运行效果如下:
以上就是归档的简单使用方法,在阅读知名第三方库源码时也经常看到了归档的使用,所以学习一下还是有必要的。
相关文章
- 从本体论开始说起——运营商关系图谱的构建及应用
- 如何成为一名数据科学家?
- 从未见过的堂兄杀了人,你的DNA是关键证据
- 20个安全可靠的免费数据源,各领域数据任你挑
- 20个安全可靠的免费数据源,各领域数据任你挑
- 阿里云李飞飞:All in Cloud时代,云原生数据库优势明显
- 基于Hadoop生态系统的一高性能数据存储格式CarbonData(性能篇)
- 大数据告诉你:10年漫威,到底有多少角色
- TigerGraph:实时图数据库助力金融风控升级
- Splunk利用Splunk Connected Experiences和Splunk Business Flow 扩大数据访问
- 大数据开发常见的9种数据分析手段
- 以免在景区看人,我爬了5W条全国景点门票数据...
- 【实战解析】基于HBase的大数据存储在京东的应用场景
- 数据科学家告诉你哪些计算机科学书籍是你应该看的
- Kafka作为大数据的核心技术,你了解多少?
- Spring Boot 整合 Redis 实现缓存操作
- 大数据学习必须掌握的五大核心技术有哪些?
- 基于Antlr在Apache Flink中实现监控规则DSL化的探索实践
- 甲骨文再次被Gartner评为分析型数据管理解决方案魔力象限领导者
- 爬取吴亦凡微博102118条转发数据,扒一扒流量的真假