使用缓存的目的是为了使用的应用程序能更快速的响应用户输入,是程序高效的运行。有时候我们需要将远程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 - 开发之内存缓存机制的更多相关文章

  1. iOS开发之内存缓存机制

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

  2. [转载]对iOS开发中内存管理的一点总结与理解

    对iOS开发中内存管理的一点总结与理解   做iOS开发也已经有两年的时间,觉得有必要沉下心去整理一些东西了,特别是一些基础的东西,虽然现在有ARC这种东西,但是我一直也没有去用过,个人觉得对内存操作 ...

  3. 内存缓存机制and垃圾回收机制

    一.内存缓存机制 var_dump(memory_get_usage(true)); $a="laruence"; var_dump(memory_get_usage(true)) ...

  4. IOS开发的内存管理

    关于IOS开发的内存管理的文章已经很多了,因此系统的知识点就不写了,这里我写点平时工作遇到的疑问以及解答做个总结吧,相信也会有人遇到相同的疑问呢,欢迎学习IOS的朋友请加ios技术交流群:190956 ...

  5. IOS开发小记-内存管理

    关于IOS开发的内存管理的文章已经很多了,因此系统的知识点就不写了,这里我写点平时工作遇到的疑问以及解答做个总结吧,相信也会有人遇到相同的疑问呢,欢迎学习IOS的朋友请加ios技术交流群:190956 ...

  6. iOS开发ARC内存管理技术要点

    本文来源于我个人的ARC学习笔记,旨在通过简明扼要的方式总结出iOS开发中ARC(Automatic Reference Counting,自动引用计数)内存管理技术的要点,所以不会涉及全部细节.这篇 ...

  7. (转)iOS开发ARC内存管理技术要点

    转自:http://www.cnblogs.com/flyFreeZn/p/4264220.html 本文来源于我个人的ARC学习笔记,旨在通过简明扼要的方式总结出iOS开发中ARC(Automati ...

  8. iOS开发——高级技术&签名机制

    签名机制 最近看了objc.io上第17期中的文章 <Inside Code Signing> 对应的中文翻译版 <代码签名探析> ,受益颇深,对iOS代码签名机制有了进一步的 ...

  9. iOS开发——OC篇&消息传递机制(KVO/NOtification/Block/代理/Target-Action)

     iOS开发中消息传递机制(KVO/NOtification/Block/代理/Target-Action)   今晚看到了一篇好的文章,所以就搬过来了,方便自己以后学习 虽然这一期的主题是关于Fou ...

随机推荐

  1. firstchild.data与childNodes[0].nodeValue意思(转)

    x.firstchild.data:获取元素第一个子节点的数据: x.childNodes[0]::获取元素第一个子节点; x.childNodes[0].nodeValue.:也是获取元素第一个子节 ...

  2. cf558c(bfs)

    C. Amr and Chemistry time limit per test 1 second memory limit per test 256 megabytes input standard ...

  3. ios 第三方登录

    ios 第三方登录通常的做法是, 1.登录后,获得第三方的uid,调用服务器登录接口,如服务器返回无此用户,转2,有此用户,转3. 2.服务器返回无此用户,需完善用户资料,如果完成,则在服务器创建与第 ...

  4. springmvc之图片上传

    1.接收到的是图片的流时 //上传头像 @RequestMapping(value = "/uploadHeadSculpture", method = RequestMethod ...

  5. 深入理解 CSS3 弹性盒布局模型

    Web 应用的样式设计中,布局是非常重要的一部分.布局用来确定页面上不同组件和元素的尺寸和位置.随着响应式用户界面的流行,Web 应用一般都要求适配不同的设备尺寸和浏览器分辨率.响应式用户界面设计中最 ...

  6. CentOS-6.5-NFS部署

                      nfs-server与nfs-client端配置一样   NFS(network file system)网络文件系统:用于在网络上共享存储. 服务端-192.16 ...

  7. CSU 1120 病毒(DP)

    题目链接:http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1120 解题报告:dp,用一个串去更新另一个串,递推方程是: if(b[i] > a ...

  8. PHP面试试题

    1,用PHP打印出前一天的时间,格式是2006-5-10 22:21:21echo date("Y:m:d H:i:s",strtotime("-1 day") ...

  9. Opencv人头跟踪检测

    //-------------------------------------人头检测------------------------------------- int main(){     //V ...

  10. 在ROS下编写自己的节点来订阅话题(C++)

    参考 http://blog.csdn.net/u013453604/article/details/49102957     的博客,其实这些内容和 <开源机器人操作系统> 这本书差不多 ...