加载网络图片可以说是网络应用中必备的。如果单纯的去下载图片,而不去做多线程、缓存等技术去优化,加载图片时的效果与用户体验就会很差。

一、自己实现加载图片的方法

tips:

*iOS中所有网络访问都是异步的.(自己开线程去下载) *普通为模型增加UIImage属性的方法做的是内存缓存(下次启动还需要从网络重新加载), 而要做本地缓存的话,还要自己手动存储网络上下载的图片. *为了加快访问, 还需要自己去弄缓存.(内存缓存或者本地缓存) *当图片没有下载完成时,还要设置占位图片。

以下代码用NSOperation开异步线程下载图片,当下载完成时替换占位图片。

01.//
02.//  XNViewController.m
03.//  加载网络图片, 普通的用NSOperation来做.
04.//
05.//  Created by neng on 14-7-7.
06.//  Copyright (c) 2014年 neng. All rights reserved.
07.//
08. 
09.#import "XNViewController.h"
10.#import "XNApp.h"
11. 
12.@interface XNViewController ()
13.@property (nonatomic, strong) NSArray *appList;
14.@property (nonatomic, strong) NSOperationQueue *queue;
15.@end
16. 
17.@implementation XNViewController
18.#pragma mark - 懒加载
19. 
20.- (NSOperationQueue *)queue {
21.if (!_queue) _queue = [[NSOperationQueue alloc] init];
22.return _queue;
23.}
24. 
25.//可抽取出来写到模型中
26.- (NSArray *)appList {
27.if (!_appList) {
28.//1.加载plist到数组中
29.NSURL *url = [[NSBundle mainBundle] URLForResource:@"apps.plist" withExtension:nil];
30.NSArray *array = [NSArray arrayWithContentsOfURL:url];
31.//2.遍历数组
32.NSMutableArray *arrayM = [NSMutableArray array];
33.[array enumerateObjectsUsingBlock: ^(id obj, NSUInteger idx, BOOL *stop) {
34.[arrayM addObject:[XNApp appWithDict:obj]];  //数组中存放的是字典, 转换为app对象后再添加到数组
35.}];
36._appList = [arrayM copy];
37.}
38.return _appList;
39.}
40. 
41.- (void)viewDidLoad {
42.[super viewDidLoad];
43. 
44.self.tableView.rowHeight = 88;
45. 
46.//    NSLog(@"appList-%@",_appList);
47.}
48. 
49.#pragma mark - 数据源方法
50.- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
51.return self.appList.count;
52.}
53. 
54.- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
55.static NSString *ID = @"Cell";
56.UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
57. 
58.//用模型来填充每个cell
59.XNApp *app = self.appList[indexPath.row];
60.cell.textLabel.text = app.name;  //设置文字
61. 
62.//设置图像: 模型中图像为nil时用默认图像,并下载图像. 否则用模型中的内存缓存图像.
63.if (!app.image) {
64.cell.imageView.image = [UIImage imageNamed:@"user_default"];
65. 
66.[self downloadImg:indexPath];
67.}
68.else {
69.//直接用模型中的内存缓存
70.cell.imageView.image = app.image;
71.}
72.//  NSLog(@"cell--%p", cell);
73. 
74.return cell;
75.}
76. 
77./**始终记住, 通过模型来修改显示. 而不要试图直接修改显示*/
78.- (void)downloadImg:(NSIndexPath *)indexPath {
79.XNApp *app  = self.appList[indexPath.row]; //取得改行对应的模型
80. 
81.[self.queue addOperationWithBlock: ^{
82.NSData *imgData = [NSData dataWithContentsOfURL:[NSURL URLWithString:app.icon]]; //得到图像数据
83.UIImage *image = [UIImage imageWithData:imgData];
84. 
85.//在主线程中更新UI
86.[[NSOperationQueue mainQueue] addOperationWithBlock: ^{
87.//通过修改模型, 来修改数据
88.app.image = image;
89.//刷新指定表格行
90.[self.tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationNone];
91.}];
92.}];
93.}
94. 
95.@end

上述代码只是做了内存缓存,而每次重新进入应用时,还会从网上重新下载。如果要继续优化上面的代码,需要自己去实现本地缓存。

二、使用第三方框架SDWebImage。(非常优秀)

*特点 :依赖的库很少.功能全面。 *自动实现磁盘缓存: *缓存图片名字是以MD5进行加密的后的名字进行命名.(因为加密那堆字串是唯一的) *[imageViewsd_setImageWithURL:v.fullImageURL placeholderImage:[UIImage imageNamed:@”xxxxx”]]. *就一个方法就实现了多线程带缓冲等效果.(可用带参数的方法,具体可看头文件)
用SDWebImage修改上面的方法后的代码可简化为:

01.#pragma mark - 数据源方法
02.- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
03.return self.appList.count;
04.}
05. 
06.- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
07.static NSString *ID = @"Cell";
08.UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
09. 
10.//用模型来填充每个cell
11.XNApp *app = self.appList[indexPath.row];
12.cell.textLabel.text = app.name;  //设置文字
13. 
14.//  //设置图像: 模型中图像为nil时用默认图像,并下载图像. 否则用模型中的内存缓存图像.
15.//  if (!cell.imageView.image) {
16.//      cell.imageView.image = [UIImage imageNamed:@"user_default"];
17.//
18.//      [self downloadImg:indexPath];
19.//  }
20.//  else {
21.//      //直接用模型中的内存缓存
22.//      cell.imageView.image = app.image;
23.//  }
24. 
25. 
26.//使用SDWebImage来完成上面的功能. 针对ImageView.
27.//一句话, 自动实现了异步下载. 图片本地缓存. 网络下载. 自动设置占位符.
28.[cell.imageView sd_setImageWithURL:[NSURL URLWithString:app.icon] placeholderImage:[UIImage imageNamed:@"user_default"]];
29. 
30. 
31.return cell;
32.}
33. 
34./**始终记住, 通过模型来修改显示. 而不要试图直接修改显示*/
35.//- (void)downloadImg:(NSIndexPath *)indexPath {
36.//  XNApp *app  = self.appList[indexPath.row]; //取得改行对应的模型
37.//
38.//  [self.queue addOperationWithBlock: ^{
39.//      NSData *imgData = [NSData dataWithContentsOfURL:[NSURL URLWithString:app.icon]]; //得到图像数据
40.//      UIImage *image = [UIImage imageWithData:imgData];
41.//
42.//      //在主线程中更新UI
43.//      [[NSOperationQueue mainQueue] addOperationWithBlock: ^{
44.//          //通过修改模型, 来修改数据
45.//          app.image = image;
46.//          //刷新指定表格行
47.//          [self.tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationNone];
48.//      }];
49.//  }];
50.//}
51. 
52.@end

SDWebImage中的一些参数: *SDWebImageRetryFailed = 1<< 0, 默认选项,失败后重试 *SDWebImageLowPriority = 1<< 1, 使用低优先级 *SDWebImageCacheMemoryOnly = 1<< 2, 仅仅使用内存缓存 *SDWebImageProgressiveDownload = 1<< 3, 显示现在进度 *SDWebImageRefreshCached = 1<< 4, 刷新缓存 *SDWebImageContinueInBackground =1 << 5, 后台继续下载图像 *SDWebImageHandleCookies = 1<< 6, 处理Cookie *SDWebImageAllowInvalidSSLCertificates= 1 << 7, 允许无效的SSL验证 *SDWebImageHighPriority = 1<< 8, 高优先级 *SDWebImageDelayPlaceholder = 1<< 9 延迟显示占位图片

出处:http://blog.csdn.net/xn4545945

iOS网络加载图片缓存与SDWebImage的更多相关文章

  1. iOS网络加载图片缓存策略之ASIDownloadCache缓存优化

    iOS网络加载图片缓存策略之ASIDownloadCache缓存优化   在我们实际工程中,很多情况需要从网络上加载图片,然后将图片在imageview中显示出来,但每次都要从网络上请求,会严重影响用 ...

  2. LruCache:从网络加载图片缓存实例

    OOM异常 堆内存用于存储实例对象,当程序不断创建对象,并且对象都有引用指向,那么垃圾回收机制就不会清理这些对象,当对象多到挤满堆内存的上限后,就产生OOM异常.Android系统为每个应用程序使用的 ...

  3. 【转】Android循环滚动广告条的完美实现,封装方便,平滑过渡,从网络加载图片,点击广告进入对应网址

    Android循环滚动广告条的完美实现,封装方便,平滑过渡,从网络加载图片,点击广告进入对应网址 关注finddreams,一起分享,一起进步: http://blog.csdn.net/finddr ...

  4. swift 基础小结01 --delegate、Optional、GCD的使用、request请求、网络加载图片并保存到沙箱、闭包以及桥接

    本文主要记录swift中delegate的使用.“?!”Optional的概念.GCD的使用.request请求.网络加载图片并保存到沙箱.闭包以及桥接. 一.delegate的使用 swift中de ...

  5. android 网络加载图片,对图片资源进行优化,并且实现内存双缓存 + 磁盘缓存

    经常会用到 网络文件 比如查看大图片数据 资源优化的问题,当然用开源的项目  Android-Universal-Image-Loader  或者 ignition 都是个很好的选择. 在这里把原来 ...

  6. ios -网络加载json和本地加载json

    1网络加载json的时候,要在模型的实现文件里写: - (void)setValue:(id)value forKey:(NSString *)key { } 2本地加载json的时候,要在模型的实现 ...

  7. Glide加载图片缓存库出现——You cannot start a load for a destroyed activity

    请记住一句话:不要再非主线程里面使用Glide加载图片,如果真的使用了,请把context参数换成getApplicationContext.

  8. 关于ios异步加载图片的几个开源项目

    一.HjCache  原文:http://www.markj.net/hjcache-iphone-image-cache/ 获取 HJCache: HJCache is up on github h ...

  9. 使用自定义的item、Adapter和AsyncTask、第三方开源框架PullToRefresh联合使用实现自定义的下拉列表(从网络加载图片显示在item中的ImageView)

    AsyncTask使用方法详情:http://www.cnblogs.com/zzw1994/p/4959949.html 下拉开源框架PullToRefresh使用方法和下载详情:http://ww ...

随机推荐

  1. Python【读写Json文件】

    indent=10:缩进10个空格

  2. 并发库应用之四 & 线程锁Lock应用

    Java5的线程并发库中,提供了相应的线程锁接口Lock来帮助我们同步处理.Lock比传统线程模型中的synchronized更加面向对象,锁本身也是一个对象,两个线程执行的代码要实现同步互斥效果,就 ...

  3. vuejs实现数据驱动视图原理

    什么是数据驱动 数据驱动是vuejs最大的特点.在vuejs中,所谓的数据驱动就是当数据发生变化的时候,用户界面发生相应的变化,开发者不需要手动的去修改dom. 比如说我们点击一个button,需要元 ...

  4. vue短信验证性能优化写入localstorage中

    平时我们在项目中进行注册等的时候,会经常用到短信验证的功能,但是现在现在很多短信验证都是存在下面几个问题,例如短信验证时间为60s的时候, 1. 当点击完按钮时,倒计时还没到60s过完时,刷新浏览器, ...

  5. 哈密顿图 哈密顿回路 哈密顿通路(Hamilton)

    本文链接:http://www.cnblogs.com/Ash-ly/p/5452580.html 概念: 哈密顿图:图G的一个回路,若它通过图的每一个节点一次,且仅一次,就是哈密顿回路.存在哈密顿回 ...

  6. numpy基础整理

    记笔记用jupyter实在太方便了,懒得再重新写到博客园上,直接放个链接吧→_→ numpy(一):https://douzujun.github.io/page/%E6%95%B0%E6%8D%AE ...

  7. python学习笔记3-函数,判断负小数

    一.函数 def hello(file_name,content): #形参file_name content f=open(file_name,'a+') f.seek(0) f.write(con ...

  8. HDU 4720 Naive and Silly Muggles 平面几何

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4720 解题报告:给出一个三角形的三个顶点坐标,要求用一个最小的圆将这个三个点都包含在内,另外输入一个点 ...

  9. Linux dig命令

    dig(Domain Information Groper),和nslookup作用有些类似,都是DNS查询工具 1.dig命令格式 dig @dnsserver name querytype 如果你 ...

  10. 【译】第六篇 Integration Services:初级工作流管理

    本篇文章是Integration Services系列的第六篇,详细内容请参考原文. 简介在前几篇文章中,我们关注使用增量加载方式加载数据.在本篇文章,我们将关注使用优先约束管理SSIS控制流中的工作 ...