SDWebImage的源码以及结构解析(1)

本文将会对图片下载缓存的三方库SDWebImage进行一定的结构解析,具体的源码注释见本人github:https://github.com/jiulin/SDWebImageNote.git

SDWebImage这个开源框架的主要作用就是:
Asynchronous image downloader with cache support with an UIImageView category.

一个异步下载图片并且支持缓存的 UIImageView 分类.

1.结构解析

这张图片已经将这个框架是如何组织的基本展示了出来, UIImageView+WebCache 和 UIButton+WebCache 使用category的方法,直接为表层的 UIKit 框架提供接口。 而 SDWebImageManger 负责处理和协调 SDWebImageDownloader 和 SDWebImageCache. 并与 UIKit 层进行交互, 实现category的方法。而底层的一些类为更高层级的抽象提供支持.

通过使用category从而为UIImageView提供方便的图片下载方法。
UIImageView+WebCache:
一般调用方法为:

[self.imageView sd_setImageWithURL:[NSURL URLWithString:@"url"] placeholderImage:[UIImage imageNamed:@"placeholder.png"]]

这个框架的设计还是极其的优雅和简洁, 主要的功能就是这么一行代码, 而其中复杂的实现细节全部隐藏在这行代码之后, 正应了那句话:把简洁留给别人, 把复杂留给自己.

编程和做人说话是一样。暴露接口就要思考:其他的类有没有必要知道这些。他是不是只需要调用就可以了。他有没有必要知道具体是怎么实现的。

接下来就看看它一层一层的封装的思想:

这category类只需要向外提供下载的接口,返回图片结果的回调。而实现下载的过程则使用SDWebImageManager进行管理。此时下载的过程分为:首先查找缓存,其次是网络下载。于是使用SDImageCache管理缓存,使用SDWebImageDownloader管理网络下载,而具体的网络下载使用SDWebImageDownloaderOperation管理NSURLConnection控制网络下载数据。

2.关键提要

SD的基本思想:每次下载图片的时候都会首先从内存缓存中查找图片资源,如果没有然后从磁盘中查找图片,最后选择网络下载。

(1)[self sd_cancelCurrentImageLoad];

SDWebImage 使用一个跟当前UIView关联operationDictionary来管理操作的。这里的cancel只与当前的UIView有关,与其他的View是无关的。

实际上SDWebImage所有操作都是通过一个 operationDictionary 来管理, 而这个字典实际上是动态的添加到当前的 UIView 上的一个属性,添加到 UIView 上, 主要是因为这个 operationDictionary 需要在 UIButton 和 UIImageView 上重用, 所以需要添加到它们的根类上.

这行代码是要保证没有当前正在进行的异步下载操作, 不会与即将进行的操作发生冲突, 它会调用:

[self sd_cancelImageLoadOperationWithKey:@"UIImageViewImageLoad"];
这个方法会使当前 UIImageView 中的所有操作都被 cancel. 不会影响之后进行的下载操作.


(2)SDWebImage通过记录failedURLs来适当的减少网络请求的不必要的开销。它会把下载失败的url进行记录failedURLs。下次使用相同的url请求的时候,则会根据设置和failedURLs中是否包含该url来判断是否还会下载url的内容。对于failedURLs则每次访问的时候都会创建互斥锁@synchronized,防止其他线程修改failedURLs。因为在其他线程,当图片再次被下载成功的时候那条成功的url会从failedURLs中移除掉。


(3)其他的后续新的会继续跟新。

SDWebImage的设计思想还是值得学习的,面向对象的封装,拿捏的恰到好处。向外暴露需要的接口,没有半点废话多言。

本文全属个人见解,如果您认为说法不正确或者哪里有错误的地方,请在评论中留言或者使用以下联系方式,笔者会在第一时间修正!!!同时也欢迎大家一起交流!

联系方式:QQ:983202699

关注微博私信:http://weibo.com/490jiulin/home?wvr=5

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容