SDWebImage提供了以下三個category來進行緩存。html
以最爲經常使用的UIImageView爲例:git
- UIImageView+WebCache:
setImageWithURL:placeholderImage:options:
先顯示 placeholderImage ,同時由SDWebImageManager 根據 URL 來在本地查找圖片。 - SDWebImageManager:
downloadWithURL:delegate:options:userInfo:
SDWebImageManager是將UIImageView+WebCache同SDImageCache連接起來的類, SDImageCache:queryDiskCacheForKey:delegate:userInfo:
用來從緩存根據CacheKey查找圖片是否已經在緩存中 - 若是內存中已經有圖片緩存, SDWebImageManager會回調SDImageCacheDelegate :
imageCache:didFindImage:forKey:userInfo:
- 而 UIImageView+WebCache 則回調SDWebImageManagerDelegate:
webImageManager:didFinishWithImage:
來顯示圖片。 - 若是內存中沒有圖片緩存,那麼生成 NSInvocationOperation 添加到隊列,從硬盤查找圖片是否已被下載緩存。
- 根據 URLKey 在硬盤緩存目錄下嘗試讀取圖片文件。這一步是在 NSOperation 進行的操做,因此回主線程進行結果回調
notifyDelegate:
。 - 若是上一操做從硬盤讀取到了圖片,將圖片添加到內存緩存中(若是空閒內存太小,會先清空內存緩存)。SDImageCacheDelegate 回調
imageCache:didFindImage:forKey:userInfo:
。進而回調展現圖片。 - 若是從硬盤緩存目錄讀取不到圖片,說明全部緩存都不存在該圖片,須要下載圖片,回調
imageCache:didNotFindImageForKey:userInfo:
。 - 共享或從新生成一個下載器
SDWebImageDownloader
開始下載圖片。 - 圖片下載由 NSURLConnection 來作,實現相關 delegate 來判斷圖片下載中、下載完成和下載失敗。
connection:didReceiveData:
中利用 ImageIO 作了按圖片下載進度加載效果。connectionDidFinishLoading:
數據下載完成後交給SDWebImageDecoder
作圖片解碼處理。- 圖片解碼處理在一個 NSOperationQueue 完成,不會拖慢主線程 UI。若是有須要對下載的圖片進行二次處理,最好也在這裏完成,效率會好不少。
- 在主線程
notifyDelegateOnMainThreadWithInfo:
宣告解碼完成,imageDecoder:didFinishDecodingImage:userInfo:
回調給 SDWebImageDownloader。 imageDownloader:didFinishWithImage:
回調給 SDWebImageManager 告知圖片下載完成。- 通知全部的 downloadDelegates 下載完成,回調給須要的地方展現圖片。
- 將圖片保存到 SDImageCache 中,內存緩存和硬盤緩存同時保存。
- 寫文件到硬盤在單獨 NSInvocationOperation 中完成,避免拖慢主線程。
- 若是是在iOS上運行,SDImageCache 在初始化的時候會註冊notification 到 UIApplicationDidReceiveMemoryWarningNotification 以及 UIApplicationWillTerminateNotification,在內存警告的時候清理內存圖片緩存,應用結束的時候清理過時圖片。
SDWebImagePrefetcher
能夠預先下載圖片,方便後續使用。