SDWebImage

SDWebImage介紹

  • OS中著名的網(wǎng)絡(luò)圖片處理框架.
  • 包含的功能:圖片下載,圖片緩存,下載進度監(jiān)聽,GIF處理等.
    用法簡單,功能強大,大大提高了網(wǎng)絡(luò)圖片的處理效率.
  • 國內(nèi)超過90%的iOS項目都有他的影子.

SDWebImage原理

  • 這個類庫提供一個UIImageView類別以支持加載網(wǎng)絡(luò)的遠程圖片.具有緩存管理/異步下載,同一個URL下載次數(shù)控制和優(yōu)化等特征.

SDWebImage加載圖片的流程

1.入口 setImageWithURL:placeholderImage:options: 會先把 placeholderImage 顯示萨脑,然后 SDWebImageManager 根據(jù) URL 開始處理圖片。

2.進入SDWebImageManager-downloadWithURL:delegate:options:userInfo:,交給 SDImageCache 從緩存查找圖片是否已經(jīng)下載 queryDiskCacheForKey:delegate:userInfo:

3.先從內(nèi)存圖片緩存查找是否有圖片析孽,如果內(nèi)存中已經(jīng)有圖片緩存,SDImageCacheDelegate 回調(diào) imageCache:didFindImage:forKey:userInfo: 到 SDWebImageManager停局。

4.SDWebImageManagerDelegate 回調(diào) webImageManager:didFinishWithImage:到 UIImageView+WebCache 等前端展示圖片岛抄。

5.如果內(nèi)存緩存中沒有,生成 NSInvocationOperation 添加到隊列開始從硬盤查找圖片是否已經(jīng)緩存弧可。

6.根據(jù) URLKey 在硬盤緩存目錄下嘗試讀取圖片文件。這一步是在 NSOperation 進行的操作劣欢,所以回主線程進行結(jié)果回調(diào) notifyDelegate:棕诵。

7.如果上一操作從硬盤讀取到了圖片,將圖片添加到內(nèi)存緩存中(如果空閑內(nèi)存過小凿将,會先清空內(nèi)存緩存)校套。SDImageCacheDelegate回調(diào) imageCache:didFindImage:forKey:userInfo:,進而回調(diào)展示圖片。

8.如果從硬盤緩存目錄讀取不到圖片牧抵,說明所有緩存都不存在該圖片笛匙,需要下載圖片,回調(diào) imageCache:didNotFindImageForKey:userInfo:犀变。

9.共享或重新生成一個下載器SDWebImageDownloader 開始下載圖片妹孙。

10.圖片下載由 NSURLConnection 來做,實現(xiàn)相關(guān) delegate 來判斷圖片下載中获枝、下載完成和下載失敗蠢正。

11.connection:didReceiveData:中利用 ImageIO 做了按圖片下載進度加載效果。

12.connectionDidFinishLoading:數(shù)據(jù)下載完成后交給 SDWebImageDecoder 做圖片解碼處理省店。

13.圖片解碼處理在一個 NSOperationQueue 完成嚣崭,不會拖慢主線程 UI笨触。如果有需要對下載的圖片進行二次處理,最好也在這里完成雹舀,效率會好很多芦劣。

14.在主線程 notifyDelegateOnMainThreadWithInfo: 宣告解碼完成,imageDecoder:didFinishDecodingImage:userInfo: 回調(diào)給 SDWebImageDownloader葱跋。

15.imageDownloader:didFinishWithImage:回調(diào)給 SDWebImageManager 告知圖片下載完成持寄。

16.通知所有的 downloadDelegates下載完成,回調(diào)給需要的地方展示圖片娱俺。

17.將圖片保存到 SDImageCache 中稍味,內(nèi)存緩存和硬盤緩存同時保存。寫文件到硬盤也在以單獨 NSInvocationOperation 完成荠卷,避免拖慢主線程模庐。

18.SDImageCache 在初始化的時候會注冊一些消息通知,在內(nèi)存警告或退到后臺的時候清理內(nèi)存圖片緩存油宜,應(yīng)用結(jié)束的時候清理過期圖片掂碱。

19.SDWebImage也提供了 UIButton+WebCache和 MKAnnotationView+WebCache,方便使用慎冤。

20.SDWebImagePrefetcher 可以預(yù)先下載圖片疼燥,方便后續(xù)使用

SDWebImage庫的作用

通過對UIImageView的類別擴展來實現(xiàn)異步加載替換圖片的工作。主要用到的對象:1蚁堤、UIImageView (WebCache)類別醉者,入口封裝,實現(xiàn)讀取圖片完成后的回調(diào)2披诗、SDWebImageManager撬即,對圖片進行管理的中轉(zhuǎn)站,記錄那些圖片正在讀取呈队。向下層讀取Cache(調(diào)用SDImageCache)剥槐,或者向網(wǎng)絡(luò)讀取對象(調(diào)用SDWebImageDownloader) 。實現(xiàn)SDImageCache和SDWebImageDownloader的回調(diào)宪摧。3粒竖、SDImageCache,根據(jù)URL的MD5摘要對圖片進行存儲和讀燃赣凇(實現(xiàn)存在內(nèi)存中或者存在硬盤上兩種實現(xiàn))實現(xiàn)圖片和內(nèi)存清理工作蕊苗。4、SDWebImageDownloader孩革,根據(jù)URL向網(wǎng)絡(luò)讀取數(shù)據(jù)(實現(xiàn)部分讀取和全部讀取后再通知回調(diào)兩種方式)其他類:SDWebImageDecoder岁歉,異步對圖像進行了一次解壓??
1得运、SDImageCache是怎么做數(shù)據(jù)管理的?SDImageCache分兩個部分膝蜈,一個是內(nèi)存層面的锅移,一個是硬盤層面的。內(nèi)存層面的相當是個緩存器饱搏,以Key-Value的形式存儲圖片非剃。當內(nèi)存不夠的時候會清除所有緩存圖片。用搜索文件系統(tǒng)的方式做管理推沸,文件替換方式是以時間為單位备绽,剔除時間大于一周的圖片文件。當SDWebImageManager向SDImageCache要資源時鬓催,先搜索內(nèi)存層面的數(shù)據(jù)肺素,如果有直接返回,沒有的話去訪問磁盤宇驾,將圖片從磁盤讀取出來倍靡,然后做Decoder,將圖片對象放到內(nèi)存層面做備份课舍,再返回調(diào)用層塌西。
2、為啥必須做Decoder?由于UIImage的imageWithData函數(shù)是每次畫圖的時候才將Data解壓成ARGB的圖像筝尾,所以在每次畫圖的時候捡需,會有一個解壓操作,這樣效率很低筹淫,但是只有瞬時的內(nèi)存需求站辉。為了提高效率通過SDWebImageDecoder將包裝在Data下的資源解壓,然后畫在另外一張圖片上贸街,這樣這張新圖片就不再需要重復(fù)解壓了庵寞。這種做法是典型的空間換時間的做法。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末薛匪,一起剝皮案震驚了整個濱河市捐川,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌逸尖,老刑警劉巖古沥,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異娇跟,居然都是意外死亡岩齿,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進店門苞俘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來盹沈,“玉大人,你說我怎么就攤上這事吃谣∑蚍猓” “怎么了做裙?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長肃晚。 經(jīng)常有香客問我锚贱,道長,這世上最難降的妖魔是什么关串? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任拧廊,我火速辦了婚禮,結(jié)果婚禮上晋修,老公的妹妹穿的比我還像新娘吧碾。我一直安慰自己,他們只是感情好墓卦,可當我...
    茶點故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布滤港。 她就那樣靜靜地躺著,像睡著了一般趴拧。 火紅的嫁衣襯著肌膚如雪溅漾。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天著榴,我揣著相機與錄音添履,去河邊找鬼。 笑死脑又,一個胖子當著我的面吹牛暮胧,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播问麸,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼往衷,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了严卖?” 一聲冷哼從身側(cè)響起席舍,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎哮笆,沒想到半個月后来颤,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡稠肘,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年福铅,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片项阴。...
    茶點故事閱讀 39,703評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡滑黔,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情略荡,我是刑警寧澤色查,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站撞芍,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏跨扮。R本人自食惡果不足惜序无,卻給世界環(huán)境...
    茶點故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望衡创。 院中可真熱鬧帝嗡,春花似錦、人聲如沸璃氢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽一也。三九已至巢寡,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間椰苟,已是汗流浹背抑月。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留舆蝴,地道東北人谦絮。 一個月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像洁仗,于是被迫代替她去往敵國和親层皱。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,601評論 2 353

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