AJ学IOS(55)多线程网络之图片下载框架之SDWebImage

时间:2023-01-01 09:04:52

AJ分享,必须精品

效果:

AJ学IOS(55)多线程网络之图片下载框架之SDWebImage

代码:

- (NSArray *)apps
{
if (!_apps) {
NSArray *dictArray = [NSArray arrayWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"apps.plist" ofType:nil]]; NSMutableArray *appArray = [NSMutableArray array];
for (NSDictionary *dict in dictArray) {
HMApp *app = [HMApp appWithDict:dict];
[appArray addObject:app];
}
_apps = appArray;
}
return _apps;
} - (void)viewDidLoad
{
[super viewDidLoad]; } #pragma mark - 数据源方法
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return self.apps.count;
} - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *ID = @"app";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
if (!cell) {
cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:ID];
} // 得到数据模型
HMApp *app = self.apps[indexPath.row]; //设置cell的标题
cell.textLabel.text = app.name;
//设置cell的下载次数
cell.detailTextLabel.text = app.download; //站位图片
UIImage *place = [UIImage imageNamed:@"57437179_42489b0"];
//用SDWebImage框架一句话解决异步下载,缓存,沙盒缓存等操作,并设置给cell的图片
[cell.imageView setImageWithURL:[NSURL URLWithString:app.icon] placeholderImage:place]; return cell;
}

自己实现图片异步下载沙盒缓存等操作的思路图(面试)

AJ学IOS(55)多线程网络之图片下载框架之SDWebImage

SDWebImage

简介:
1:SDWebImage是:iOS中著名的牛逼的网络图片处理框架。
2:包含的功能:图片下载、图片缓存、下载进度监听、gif处理等等。
3:用法极其简单,功能十分强大,大大提高了网络图片的处理效率。
4:国内超过90%的iOS项目都有它的影子。

使用步骤

第一步,下载SDWebImage,导入工程。github托管地址https://github.com/rs/SDWebImage

第二步,在需要的地方导入头文件

#import "UIImageView+WebCache.h"

第三步,调用sd_setImageWithURL:等等方法旧的版本里面都没有sd开头。

二:重点:需要记住的几个常用方法

1 常用方法

//设置下载图片的链接和站位图片
- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder;

//设置下载图片的链接和站位图片以及一个选项的集合options
- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options;

SDWebImageOptions(上面方法中的options)
* SDWebImageRetryFailed : 下载失败后,会自动重新下载
* SDWebImageLowPriority : 当正在进行UI交互时,自动暂停内部的一些下载操作
* SDWebImageRetryFailed | SDWebImageLowPriority : 拥有上面2个功能

  //失败后重试
SDWebImageRetryFailed = 1 << 0, //UI交互期间开始下载,导致延迟下载比如UIScrollView减速。
SDWebImageLowPriority = 1 << 1, //只进行内存缓存
SDWebImageCacheMemoryOnly = 1 << 2, //这个标志可以渐进式下载,显示的图像是逐步在下载
SDWebImageProgressiveDownload = 1 << 3, //刷新缓存
SDWebImageRefreshCached = 1 << 4, //后台下载
SDWebImageContinueInBackground = 1 << 5, //NSMutableURLRequest.HTTPShouldHandleCookies = YES; SDWebImageHandleCookies = 1 << 6, //允许使用无效的SSL证书
//SDWebImageAllowInvalidSSLCertificates = 1 << 7, //优先下载
SDWebImageHighPriority = 1 << 8, //延迟占位符
SDWebImageDelayPlaceholder = 1 << 9, //改变动画形象
SDWebImageTransformAnimatedImage = 1 << 10,

//设置下载图片的链接和站位图片以及完成后执行是么操作 (completed 完成)

- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder completed:(SDWebImageCompletionBlock)completedBlock;

//此方法用来做下载进度条的

- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options progress:(SDWebImageDownloaderProgressBlock)progressBlock completed:(SDWebImageCompletionBlock)completedBlock;

2 内存处理:当app接收到内存警告时

/**
* 当app接收到内存警告
*/
- (void)applicationDidReceiveMemoryWarning:(UIApplication *)application
{
SDWebImageManager *mgr = [SDWebImageManager sharedManager];

// 1.取消正在下载的操作
[mgr cancelAll]; // 2.清除内存缓存
[mgr.imageCache clearMemory];

}

3 SDWebImage内部实现过程

  1. 入口 setImageWithURL:placeholderImage:options: 会先把 placeholderImage 显示,然后 SDWebImageManager 根据 URL 开始处理图片。
    1. 进入 SDWebImageManager-downloadWithURL:delegate:options:userInfo:,交给 SDImageCache 从缓存查找图片是否已经下载 queryDiskCacheForKey:delegate:userInfo:.
    2. 先从内存图片缓存查找是否有图片,如果内存中已经有图片缓存,SDImageCacheDelegate 回调 imageCache:didFindImage:forKey:userInfo: 到 SDWebImageManager。
    3. SDWebImageManagerDelegate 回调 webImageManager:didFinishWithImage: 到 UIImageView+WebCache 等前端展示图片。
    4. 如果内存缓存中没有,生成 NSInvocationOperation 添加到队列开始从硬盘查找图片是否已经缓存。
    5. 根据 URLKey 在硬盘缓存目录下尝试读取图片文件。这一步是在 NSOperation 进行的操作,所以回主线程进行结果回调 notifyDelegate:。
    6. 如果上一操作从硬盘读取到了图片,将图片添加到内存缓存中(如果空闲内存过小,会先清空内存缓存)。SDImageCacheDelegate 回调 imageCache:didFindImage:forKey:userInfo:。进而回调展示图片。
    7. 如果从硬盘缓存目录读取不到图片,说明所有缓存都不存在该图片,需要下载图片,回调 imageCache:didNotFindImageForKey:userInfo:。
    8. 共享或重新生成一个下载器 SDWebImageDownloader 开始下载图片。
    9. 图片下载由 NSURLConnection 来做,实现相关 delegate 来判断图片下载中、下载完成和下载失败。
    10. connection:didReceiveData: 中利用 ImageIO 做了按图片下载进度加载效果。
    11. connectionDidFinishLoading: 数据下载完成后交给 SDWebImageDecoder 做图片解码处理。
    12. 图片解码处理在一个 NSOperationQueue 完成,不会拖慢主线程 UI。如果有需要对下载的图片进行二次处理,最好也在这里完成,效率会好很多。
    13. 在主线程 notifyDelegateOnMainThreadWithInfo: 宣告解码完成,imageDecoder:didFinishDecodingImage:userInfo: 回调给 SDWebImageDownloader。
    14. imageDownloader:didFinishWithImage: 回调给 SDWebImageManager 告知图片下载完成。
    15. 通知所有的 downloadDelegates 下载完成,回调给需要的地方展示图片。
    16. 将图片保存到 SDImageCache 中,内存缓存和硬盘缓存同时保存。写文件到硬盘也在以单独 NSInvocationOperation 完成,避免拖慢主线程。
    17. SDImageCache 在初始化的时候会注册一些消息通知,在内存警告或退到后台的时候清理内存图片缓存,应用结束的时候清理过期图片。
    18. SDWI 也提供了 UIButton+WebCache 和 MKAnnotationView+WebCache,方便使用。
    19. SDWebImagePrefetcher 可以预先下载图片,方便后续使用。

第三方框架的使用建议

1.用第三方框架的目的
a: 开发效率:快速开发,人家封装好的一行代码顶自己写的N行
b: 为了使用这个功能最牛逼的实现

2.第三方框架过多,很多坏处(忽略不计)
a: 管理、升级、更新
b: 第三方框架有BUG,等待作者解决
c: 第三方框架的作者不幸去世、停止更新(潜在的BUG无人解决)
d: 感觉:自己好水

比如在流媒体:播放在线视频、音频(边下载边播放)等需求上。
如果自己做需要我们非常了解音频、视频文件的格式。并且每一种视频都有自己的解码方式(C\C++),这真的很难,没有几年的深入研究真的没啥结果

4.总结
1> 站在巨人的肩膀上编程
2> 没有关系,使劲用那么比较稳定的第三方框架

ps:(SDWebImage内部实现过程引用了6duxz博客部分素材来自传智黑马的ppt)

ps2:博客内容很多事人家的上课内容,但是每一笔每一画都是AJ认真整理出来的,目的是为了方便自己复习,如果你也想学,很欢迎来交朋友。

AJ学IOS(55)多线程网络之图片下载框架之SDWebImage的更多相关文章

  1. AJ学IOS 之微博项目实战&lpar;8&rpar;用AFNetworking和SDWebImage简单加载微博数据

    AJ分享,必须精品 一:效果 没有图文混排,也没有复杂的UI,仅仅是简单的显示出微博数据,主要介绍AFNetworking和SDWebImage的简单用法 二:加载数据AFNetworking AFN ...

  2. 利用内存结构及多线程优化多图片下载&lpar;IOS篇&rpar;

    利用内存结构及多线程优化多图片下载(IOS篇) 前言 下载地址, 后续发布, 请继续关注本blog 在IOS中,我们常常遇到多图片下载的问题.最简单的解决方案是直接利用别人写好的框架.但是这如同练武, ...

  3. AJ学IOS(48)多线程网络之多线程简单了解

    AJ分享,必须精品 一:进程和线程 1:什么是进程 进程是指在系统中正在运行的一个应用程序 每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内. 比如同时打开QQ.Xcode,系统就会分 ...

  4. AJ学IOS 之微博项目实战&lpar;2&rpar;微博主框架-自定义导航控制器NavigationController

    AJ分享,必须精品 一:添加导航控制器 上一篇博客完成了对底部的TabBar的设置,这一章我们完成自定义导航控制器(NYNavigationController). 为啥要做自定义呢,因为为了更好地封 ...

  5. AJ学IOS(13)UI之UITableView学习(下)汽车名牌带右侧索引

    AJ分享,必须精品 先看效果图 代码 ViewController #import "NYViewController.h" #import "NYCarGroup.h& ...

  6. AJ学IOS(18)UI之QQ聊天布局&lowbar;键盘通知实现自动弹出隐藏&lowbar;自动回复

    AJ分享,必须精品 先看图片 第一步完成tableView和Cell的架子的图 完善图片 键盘弹出设置后图片: 自动回复图: 粗狂的架子 tableView和Cell的创建 首相tableView为了 ...

  7. iOS学习笔记之异步图片下载

    写在前面 在iOS开发中,无论是在UITableView还是在UICollectionView中,通过网络获取图片设置到cell上是较为常见的需求.尽管有很多现存的第三方库可以将下载和缓存功能都封装好 ...

  8. ios开发之网络数据的下载与上传

    要实现网络数据的下载与上传,主要有三种方式 > NSURLConnection  针对少量数据,使用“GET”或“POST”方法从服务器获取数据,使用“POST”方法向服务器传输数据; > ...

  9. 具体解说Android的图片下载框架UniversialImageLoader之磁盘缓存(一)

    沉浸在Android的开发世界中有一些年头的猴子们,预计都可以深深的体会到Android中的图片下载.展示.缓存一直是心中抹不去的痛.鄙人亦是如此.Ok,闲话不说.为了督促自己的学习.以下就逐一的挖掘 ...

随机推荐

  1. 信贷业务(Ali)

    1.信贷业务视角 信贷业务主要有两个视角,借款人和出资机构.借款人关心借多少钱,还多少钱,多少利息:机构关心信贷资产风险,收益. 领域模型上两个视角分开:个人--->账单.机构--->资产 ...

  2. django1&period;4日志模块配置及使用

    一.默认日志配置 在django 1.4中默认有一个简单的日志配置,如下 # A sample logging configuration. The only tangible logging # p ...

  3. 前端攻城狮学习笔记九:让你彻底弄清offset

    很多初学者对于JavaScript中的offset.scroll.client一直弄不明白,虽然网上到处都可以看一张图(图1),但这张图太多太杂,并且由于浏览器差异性,图示也不完全正确. 图一 不知道 ...

  4. java的nio之:java的nio的服务器实现模型

    [nio服务端序列图]

  5. 【转】WF事件驱动

    转自:http://www.cnblogs.com/Mayvar/category/315963.html 这系统的教程有代码可以下载 WF事件驱动(5) 摘要: 之前,我通过4篇文章介绍了在WF4中 ...

  6. Remove掉Request&period;QueryString

    好久上博客来了,最近有点忙,有点懒. 今天在解决一个Request.QueryString 传值的问题上遇到了,当不是第一次加载时需要把Request.QueryString的值赋值为null,刚开始 ...

  7. &lpar;后端&rpar;Mybatis中&num;&lbrace;&rcub;和&dollar;&lbrace;&rcub;传参的区别及&num;和&dollar;的区别小结&lpar;转&rpar;

    原文地址:https://www.cnblogs.com/zqr99/p/8094234.html 最近在用mybatis,之前用过ibatis,总体来说差不多,不过还是遇到了不少问题,再次记录下, ...

  8. STL容器之一vector

    STL中最简单也是最有用的容器之一是vector<T>类模板,称为向量容器,是序列类型容器中的一种. 1.vector<T> 对象的基本用法(1)声明:vector<ty ...

  9. UDP接收数据

    http://blog.csdn.net/xingzheouc/article/details/49946191 http://blog.csdn.net/robertkun/article/deta ...

  10. 原生JavaScript实现的贪吃蛇

    github代码地址:https://github.com/McRayFE/snake 涉及到的知识点: 键盘事件 setInterval()定时器 javascript中数组的使用 碰撞的检测 of ...