MyException - 我的异常网
当前位置:我的异常网» 操作系统 » IOS开发缓存机制之—内存储器缓存机制

IOS开发缓存机制之—内存储器缓存机制

www.MyException.Cn  网友分享于:2015-08-26  浏览:60次
IOS开发缓存机制之—内存缓存机制

在IOS应用程序开发中,为了减少与服务端的交互次数,加快用户的响应速度,一般都会在iOS设备中加一个缓存的机制。

这篇文章将介绍一下如何在iOS设备中进行缓存,本文先介绍一下将内容缓存到内存中,下一篇文章就介绍一下在iOS磁盘上缓存内容。

使用缓存的目的是为了使用的应用程序能更快速的响应用户输入,是程序高效的运行。有时候我们需要将远程web服务器获取的数据缓存起来,减少对同一个url多次请求。

内存缓存我们可以使用sdk中的NSURLCache类。NSURLRequest需要一个缓存参数来说明它请求的url何如缓存数据的,我们先看下它的CachePolicy类型。

1、NSURLRequestUseProtocolCachePolicy NSURLRequest默认的cache policy,使用Protocol协议定义。
2、NSURLRequestReloadIgnoringCacheData 忽略缓存直接从原始地址下载。
3、NSURLRequestReturnCacheDataElseLoad 只有在cache中不存在data时才从原始地址下载。
4、NSURLRequestReturnCacheDataDontLoad 只使用cache数据,如果不存在cache,请求失败;用于没有建立网络连接离线模式;
5、NSURLRequestReloadIgnoringLocalAndRemoteCacheData:忽略本地和远程的缓存数据,直接从原始地址下载,与NSURLRequestReloadIgnoringCacheData类似。
6、NSURLRequestReloadRevalidatingCacheData:验证本地数据与远程数据是否相同,如果不同则下载远程数据,否则使用本地数据。

NSURLCache还提供了很多方法,来方便我们实现应用程序的缓存机制。下面我通过一个例子来说明,这个例子减少我们对同一个url多次请求。看下面代码:

-(IBAction) buttonPress:(id) sender 

    NSString *paramURLAsString= @"http://www.baidu.com/"; 

    if ([paramURLAsString length] == 0){ 

        NSLog(@"Nil or empty URL is given"); 

        return; 

    } 

    NSURLCache *urlCache = [NSURLCache sharedURLCache]; 

    /* 设置缓存的大小为1M*/

    [urlCache setMemoryCapacity:1*1024*1024]; 

     //创建一个nsurl 

    NSURL *url = [NSURL URLWithString:paramURLAsString]; 

        //创建一个请求 

    NSMutableURLRequest *request = 

    [NSMutableURLRequest

     requestWithURL:url 

     cachePolicy:NSURLRequestUseProtocolCachePolicy

     timeoutInterval:60.0f]; 

     //从请求中获取缓存输出 

    NSCachedURLResponse *response = 

    [urlCache cachedResponseForRequest:request]; 

    //判断是否有缓存 

    if (response != nil){ 

        NSLog(@"如果有缓存输出,从缓存中获取数据"); 

        [request setCachePolicy:NSURLRequestReturnCacheDataDontLoad]; 

    } 

    self.connection = nil; 

    /* 创建NSURLConnection*/

    NSURLConnection *newConnection = 

    [[NSURLConnection alloc] initWithRequest:request 

                                    delegate:self

                            startImmediately:YES]; 

    self.connection = newConnection; 

    [newConnection release]; 

}

这个例子中,我们请求url为www.baidu.com的网站。如果这个url被缓存了,我们直接从缓存中获取数据,否则从www.baidu.com站点上重新获取数据。我们设置了缓存大小为1M。

使用下面代码,我将请求的过程打印出来:

- (void)  connection:(NSURLConnection *)connection 

  didReceiveResponse:(NSURLResponse *)response{ 

    NSLog(@"将接收输出"); 

- (NSURLRequest *)connection:(NSURLConnection *)connection 

             willSendRequest:(NSURLRequest *)request 

            redirectResponse:(NSURLResponse *)redirectResponse{ 

    NSLog(@"即将发送请求"); 

    return(request); 

- (void)connection:(NSURLConnection *)connection 

    didReceiveData:(NSData *)data{ 

    NSLog(@"接受数据"); 

    NSLog(@"数据长度为 = %lu", (unsigned long)[data length]); 

- (NSCachedURLResponse *)connection:(NSURLConnection *)connection 

                  willCacheResponse:(NSCachedURLResponse *)cachedResponse{ 

    NSLog(@"将缓存输出"); 

    return(cachedResponse); 

- (void)connectionDidFinishLoading:(NSURLConnection *)connection{ 

    NSLog(@"请求完成"); 

- (void)connection:(NSURLConnection *)connection 

  didFailWithError:(NSError *)error{ 

    NSLog(@"请求失败"); 

}

当我们第一次点击界面上的按钮,打印的结果如下:

2011-07-30 18:50:24.910 Caching[3971:207] 即将发送请求 

2011-07-30 18:50:28.557 Caching[3971:207] 将接收输出 

2011-07-30 18:50:31.677 Caching[3971:207] 接受数据 

2011-07-30 18:50:31.681 Caching[3971:207] 数据长度为 = 4414 

2011-07-30 18:50:31.682 Caching[3971:207] 接受数据 

2011-07-30 18:50:31.682 Caching[3971:207] 数据长度为 = 2996 

2011-07-30 18:50:38.107 Caching[3971:207] 将缓存输出 

2011-07-30 18:50:38.109 Caching[3971:207] 请求完成

 

在看我们第二次点击界面上的按钮,打印结果如下:

 

2011-07-30 18:52:18.894 Caching[3971:207] 即将发送请求
2011-07-30 18:52:18.895 Caching[3971:207] 将接收输出
2011-07-30 18:52:18.895 Caching[3971:207] 接受数据
2011-07-30 18:52:18.896 Caching[3971:207] 数据长度为 = 7410
2011-07-30 18:52:18.896 Caching[3971:207] 请求完成

我们看到没有“将缓存输出”一项,请求到的数据是第一次请求的累积,也就是第二次是从内存中获取数据的。

总结:本文简单的介绍了一下iOS的内存缓存机制,下一篇文章将重点介绍一下本地缓存机制

 

原文出处:http://blog.csdn.net/zhuqilin0/article/details/6647123#

在次感谢朱祁林 (用户名:zhuqilin0) ,谢谢他的博文

文章评论

鲜为人知的编程真相
鲜为人知的编程真相
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
总结2014中国互联网十大段子
总结2014中国互联网十大段子
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
我的丈夫是个程序员
我的丈夫是个程序员
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
Java程序员必看电影
Java程序员必看电影
Google伦敦新总部 犹如星级庄园
Google伦敦新总部 犹如星级庄园
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
2013年美国开发者薪资调查报告
2013年美国开发者薪资调查报告
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
代码女神横空出世
代码女神横空出世
程序员应该关注的一些事儿
程序员应该关注的一些事儿
 程序员的样子
程序员的样子
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
那些争议最大的编程观点
那些争议最大的编程观点
那些性感的让人尖叫的程序员
那些性感的让人尖叫的程序员
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
我是如何打败拖延症的
我是如何打败拖延症的
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
每天工作4小时的程序员
每天工作4小时的程序员
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
2013年中国软件开发者薪资调查报告
2013年中国软件开发者薪资调查报告
如何成为一名黑客
如何成为一名黑客
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
一个程序员的时间管理
一个程序员的时间管理
编程语言是女人
编程语言是女人
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
旅行,写作,编程
旅行,写作,编程
程序员的鄙视链
程序员的鄙视链
漫画:程序员的工作
漫画:程序员的工作
为什么程序员都是夜猫子
为什么程序员都是夜猫子
程序员和编码员之间的区别
程序员和编码员之间的区别
中美印日四国程序员比较
中美印日四国程序员比较
程序员必看的十大电影
程序员必看的十大电影
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有