SDWebImage的使用與實(shí)現(xiàn)原理

iOS開發(fā)中經(jīng)常會用到SDW用于下載展示網(wǎng)絡(luò)圖片归敬。那么SDW的底層是如何實(shí)現(xiàn)的响蓉?空暇之余就來整理下硕勿。

SDWebImage底層組成

1、內(nèi)存圖片緩存
2枫甲、內(nèi)存操作緩存
3源武、磁盤沙盒緩存

SDWebImage實(shí)現(xiàn)過程

首先看一下整個(gè)代碼的結(jié)構(gòu)圖


SDWebImage

step1
首先從 setImageWithURL:placeholderImage:options:進(jìn)入后會先顯示placeholderImage,然后 SDWebImageManager 根據(jù) URL 開始處理圖片想幻。
step2
調(diào)用SDWebImageManager-downloadWithURL:delegate:options:userInfo:粱栖,交給 SDImageCache 去緩存查找圖片是否存在queryDiskCacheForKey:delegate:userInfo:

step3
首先內(nèi)存中尋找緩存,若內(nèi)存中已經(jīng)有圖片緩存脏毯,**SDImageCacheDelegate **回調(diào) imageCache:didFindImage:forKey:userInfo: 到 SDWebImageManager闹究。
step3.1
SDWebImageManagerDelegate 回調(diào) webImageManager:didFinishWithImage: 到 UIImageView+WebCache 等待展示圖片。

step4
若內(nèi)存緩存中沒有食店,生成 NSInvocationOperation 添加到隊(duì)列開始從硬盤查找圖片是否已經(jīng)緩存渣淤。
step4.1
根據(jù) URLKey硬盤緩存目錄下嘗試讀取圖片文件赏寇。這一步是在 NSOperation 進(jìn)行的操作,所以回主線程進(jìn)行結(jié)果回調(diào) notifyDelegate:价认。
step4.2
若上一操作從硬盤讀取到了圖片嗅定,將圖片添加到內(nèi)存緩存中(注意是內(nèi)存緩存中哦,如果空閑內(nèi)存過小用踩,會先清空內(nèi)存緩存)渠退。SDImageCacheDelegate 回調(diào)imageCache:didFindImage:forKey:userInfo:。進(jìn)而回調(diào)展示圖片捶箱。
step4.3
如果從硬盤緩存目錄讀取不到圖片智什,說明所有沙盒緩存(即內(nèi)存和硬盤中均不存在)都不存在該圖片,此時(shí)回調(diào) imageCache:didNotFindImageForKey:userInfo:下載圖片丁屎。

step5
共享或重新生成一個(gè)下載器 SDWebImageDownloader 開始下載圖片荠锭。
step5.1
圖片下載由 NSURLConnection 來做,實(shí)現(xiàn)相關(guān) delegate 來判斷圖片下載的進(jìn)程(下載進(jìn)行中晨川、下載完成和下載失斨ぞ拧),connection:didReceiveData: 中利用 **ImageIO **做了按圖片下載進(jìn)度加載效果共虑。
step5.2
connectionDidFinishLoading:數(shù)據(jù)下載完成后交給 SDWebImageDecoder 做圖片解碼處理愧怜。圖片解碼處理在一個(gè) NSOperationQueue 完成,不會拖慢主線程 UI妈拌。如果有需要對下載的圖片進(jìn)行二次處理拥坛,最好也在這里完成,效率會好很多尘分。
step5.3
在主線程 notifyDelegateOnMainThreadWithInfo:宣告解碼完成猜惋,imageDecoder:didFinishDecodingImage:userInfo: 回調(diào)給 SDWebImageDownloader。
step5.4
imageDownloader:didFinishWithImage: 回調(diào)給 SDWebImageManager 告知圖片下載完成培愁。
step5.5
通知所有的 downloadDelegates 下載完成著摔,回調(diào)給需要的地方展示圖片。
step5.6
將圖片保存到 SDImageCache 中定续,內(nèi)存緩存和硬盤緩存同時(shí)保存谍咆。寫文件到硬盤也在以單獨(dú) NSInvocationOperation 完成,避免拖慢主線程私股。

另外摹察,SDImageCache 在初始化的時(shí)候會注冊一些消息通知,在內(nèi)存警告或退到后臺的時(shí)候清理內(nèi)存圖片緩存倡鲸,應(yīng)用結(jié)束的時(shí)候清理過期圖片供嚎。

重寫與覆蓋

從上面流程可以看出,當(dāng)你調(diào)用setImageWithURL:方法的時(shí)候,他會自動去給你干這么多事查坪,當(dāng)你需要在某一具體時(shí)刻做事情的時(shí)候寸宏,你可以覆蓋這些方法。比如在下載某個(gè)圖片的過程中要響應(yīng)一個(gè)事件偿曙,就覆蓋這個(gè)方法:

SDWebImageManager *manager = [SDWebImageManager sharedManager];
[manager downloadImageWithURL:imagePath2 options:SDWebImageRetryFailed progress:^(NSInteger receivedSize, NSInteger expectedSize) {
     NSLog(@"顯示當(dāng)前進(jìn)度");
} completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, BOOL finished, NSURL *imageURL) {
     NSLog(@"下載完成");
}];
使用

step1 導(dǎo)入工程
step2 導(dǎo)入頭文件
step3 根據(jù)需要實(shí)現(xiàn)不同的方法


直接調(diào)用即可

具體的不同方法查看https://github.com/rs/SDWebImage

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末氮凝,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子望忆,更是在濱河造成了極大的恐慌罩阵,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件启摄,死亡現(xiàn)場離奇詭異稿壁,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)歉备,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進(jìn)店門傅是,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蕾羊,你說我怎么就攤上這事喧笔。” “怎么了龟再?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵书闸,是天一觀的道長。 經(jīng)常有香客問我利凑,道長浆劲,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任哀澈,我火速辦了婚禮牌借,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘日丹。我一直安慰自己走哺,他們只是感情好蚯嫌,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布哲虾。 她就那樣靜靜地躺著,像睡著了一般择示。 火紅的嫁衣襯著肌膚如雪束凑。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天栅盲,我揣著相機(jī)與錄音汪诉,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛扒寄,可吹牛的內(nèi)容都是我干的鱼鼓。 我是一名探鬼主播,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼该编,長吁一口氣:“原來是場噩夢啊……” “哼迄本!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起课竣,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤嘉赎,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后于樟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體公条,經(jīng)...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年迂曲,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了靶橱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,841評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡路捧,死狀恐怖抓韩,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情鬓长,我是刑警寧澤谒拴,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站涉波,受9級特大地震影響英上,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜啤覆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一苍日、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧窗声,春花似錦相恃、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至见剩,卻和暖如春杀糯,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背苍苞。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工固翰, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓骂际,卻偏偏與公主長得像疗琉,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子歉铝,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,781評論 2 354

推薦閱讀更多精彩內(nèi)容