前面两章依次介绍了实现缓存的两个步骤
- 将iOS 的JSON数据转化成model即模型数据
- 将iOS 的模型数据实现自动归档
为何要介绍上述两个方法呢?
有一下几点原因考虑
1. 如果将JSON作为数据进行缓存,确实是可以的。但这样有一个问
题,如果一个tableView页面的数据比较多,比如有30多个cell,如
果一个cell里面的数据也很复杂。那么此时从文件中读取 JSON再
转化成模型,再从模型生成view,耗费的时间是不可估量的。
在应用中我曾今体会到这样导致页面切换时卡顿的现象,所以这种方法
不可行
2. 除了上面的缓存JSON数据,现在可以介绍的是直接缓存用户的
模型。没错,就是直接把模型转化成NSData,然后进行存储的过
程。
通过前面两节课后,已经能够将json转化成模型,并且能够将模型直接
转化成NSData进行存储了。
这里就进行缓存的介绍。
缓存分为两个部分
- 内存中缓存
- 磁盘中缓存
上述两个部分缺一不可。对于频繁需要读取的数据,需要把数据存储在内存中
同时每一分存储到内存中的数据,在磁盘中也需要有一份备份,这样当程序
再次进入当前页面的时候(内存中此时还没有数据时),可以从磁盘中读取缓存进行加载。
内存中缓存
内存中缓存时,使用一个NSMutabledictionary存储key-value值,
当,存缓存时,使用 setObject:forKey的方法存对象,读取时使用
objectForKey:读取对象
磁盘中缓存
内存中存储了一个key值的value之后,需要在磁盘中保存此份对象。首先将该对象通过归档转变成一个NSData,然后根据关键字创建磁盘中的文件,将该数据NSData写入该文件中即可。
对于在NSMutableiDictionary中未曾读到对象时,可以根据俄key索引本地磁盘,如果存在该文件,那么将该文件通过解档还原成对象,同时在NSMutabledictionary中存储一次该对象即可。
线程安全
对于频繁操作NSMutabledictionary 以及频繁操作本地文件的缓存操作
要确保线程安全。
比如有两个任务需要同时读取文件,那么这两个操作有可能操作同一个文件。
线程安全时,这两个操作必须要先后进行,可以且必须采取 串行队列
进行读取,这样不管有多少个任务进行缓存,都会有一个次第顺序。
对于多个任务来说也不会出现线程安全的问题。
存储一个对象的代码如下:
-(void)setObject:(id)obj forKey:(NSString *)key userId:(NSString *)uid useArchive:(ArchiveType)needArchive
{
if (!uid || !key || !obj) {
return;
}
__weak typeof(self) weakSelf = self;
dispatch_async(self.ioQueue_busy, ^{
//串行队列
id memoryObj = nil;
NSMutableData *data = nil;
if (!needArchive) {