前面一片文章介绍了如何上传和下载文件,这篇文章将介绍一下如何在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类似。
6NSURLRequestReloadRevalidatingCacheData:验证本地数据与远程数据是否相同,如果不同则下载远程数据,否则使用本地数据。
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的内存缓存机制,下一篇文章将重点介绍一下本地缓存机制。
相关推荐
3. 监听缓存行为:虽然`UIWebView`默认会处理`NSURLCache`,但我们可以通过实现`UIWebViewDelegate`中的`webView(_:didReceiveResponse:)`方法,来获取关于是否使用了缓存的信息。 ```swift func webView(_ webView:...
- `+ (void)setSharedURLCache:(NSURLCache *)cache`:设置自定义的NSURLCache实例作为应用的缓存管理器。 - `- (instancetype)initWithMemoryCapacity:(NSUInteger)memoryCapacity diskCapacity:(NSUInteger)...
这是NSURLCache子类,用于处理使用NSURLRequest的所有Web请求。 (包括UIWebView) EVURLCache用于处理以下缓存策略: 即使没有互联网连接,该应用程序也必须能够正常运行。 从应用商店下载应用后,该应用必须立即...
然后,我们需要在应用启动时创建这个自定义的NSURLCache实例,并替换默认的NSURLCache,这样URL Loading System在处理请求时就会调用我们的拦截逻辑。创建新的缓存时,需要指定一个存储路径,通常是在应用的沙盒内的...
iOS系统缓存方面的开发对于提升应用程序的性能至关重要,尤其是在处理...通过合理配置`NSURLCache`和选择合适的缓存策略,开发者可以优化网络请求,减少不必要的网络流量,并在离线状态下提供一定程度的数据访问能力。
为了使UIWebView使用我们自定义的NSURLCache,我们需要设置`setSharedCache:`方法,将全局的NSURLCache对象替换为我们创建的子类实例。这样,所有通过UIWebView发起的HTTP请求都会经过我们的自定义缓存处理。 此外...
在这个压缩包文件"STMURLCache-master"中,可能包含了一个自定义的URL缓存实现,如STMURLCache,它可能是对`NSURLCache`的增强,提供更灵活的缓存控制或性能优化。使用这样的库可以帮助开发者更好地管理和预加载Web...
在AFNetworking中,实现缓存的关键在于使用URLSessionConfiguration来配置网络请求,并结合NSURLCache进行数据存储。NSURLCache是一个内置的缓存系统,可以将HTTP响应存储到磁盘或内存中,当相同请求再次发起时,...
本文主要关注iOS中的内存缓存机制,即如何利用SDK中的`NSURLCache`类来存储和检索数据。 首先,`NSURLCache`是苹果提供的一个内置缓存系统,用于存储HTTP和HTTPS请求的响应数据。当应用程序发起一个网络请求时,...
[NSURLCache setSharedURLCache:cache]; }; ``` ### 七、网络状态监控 AFNetworking 还提供了 `AFNetworkReachabilityManager` 来检测网络状态: ```objc AFNetworkReachabilityManager *manager = ...
2. NSURLCache:网络请求的数据会被缓存,以便后续请求可以快速获取。NSURLCache存储HTTP和HTTPS请求的响应,包括HTML、图片等。 3. CoreData缓存:CoreData是苹果提供的持久化框架,它也会创建缓存以提高查询性能...
可以尝试关闭自动缓存,通过`setCachePolicy:`方法设置为`NSURLCacheStoragePolicy.NoCache`,并清除缓存`[[NSURLCache sharedURLCache] removeAllCachedResponses];`。 2. **避免不必要的JavaScript执行**:...
1. 设置全局缓存:在应用程序启动时,开发者可以通过`[NSURLCache sharedURLCache]`获取默认的URLCache实例,或者通过`initWithMemoryCapacity:diskCapacity:diskPath:`创建自定义的URLCache实例并设置为全局缓存。...
例如,使用NSURLCache来缓存HTTP响应,减少不必要的网络请求。 9. **上传和下载管理**:对于大文件的上传和下载,需要特别关注进度显示和断点续传。NSURLSession提供了相关的API来处理这些需求。 10. **视频讲解**...
6. **缓存策略**:通过集成NSURLCache,AFNetworking可以实现HTTP请求的本地缓存,提高用户体验。 7. **网络状态监测**:AFNetworking可以监测网络状态变化,帮助开发者优雅地处理离线情况。 8. **KVO(Key-Value ...
6. **响应缓存**:利用NSURLCache进行响应缓存,提高应用性能,减少网络延迟。 7. **请求优先级和取消**:可以设置请求的优先级,或者在必要时取消请求。 8. **错误处理**:提供统一的错误处理机制,便于调试和...
例如,使用NSURLCache可以缓存网络响应,减少不必要的网络请求;利用Grand Central Dispatch或OperationQueue可以有效地管理并发网络请求,避免阻塞主线程。 最后,书中可能还会讨论到现代网络技术,如WebSocket,...
书中将介绍如何利用NSURLCache进行数据缓存,以及自定义缓存策略。 7. **错误处理**:网络编程中错误处理至关重要。书中的代码示例会展示如何捕获和处理网络请求可能出现的各种错误,以保证应用的稳定性和可靠性。 ...
此外,还可以开启缓存机制,利用`NSURLCache`存储已加载过的网页,加快后续访问速度。 安全方面,UIWebView可能会受到跨站脚本攻击(XSS)和点击劫持等威胁。为防止这种情况,你需要对加载的内容进行过滤,确保其...