SDWebImage
SDWebImage原理
- 核心类SDWebImageManager介绍
- 图片加载
- 图片缓存
- 图片转码
- 图片下载
SDWebImageManager核心类介绍
SDWebImageManager是一个单例,SDWebImageManager
用于支撑WebCache分类
加载图片,连接SDwebImageDownloader
异步加载器和SDWebImageCache
缓存模块
主要包含
- id<SDWebImageManagerDelegate> delegate
- SDwebImageDownloader //异步下载器
- SDWebImageCache // 缓存模块
SDWebImageManagerDelegate
- (BOOL)imageManager:(nonnull SDWebImageManager *)imageManager shouldDownloadImageForURL:(nonnull NSURL *)imageURL;
- (BOOL)imageManager:(nonnull SDWebImageManager *)imageManager shouldBlockFailedURL:(nonnull NSURL *)imageURL withError:(nonnull NSError *)error;
SDWebImageManagerDelegate中包含了两个方法
- 第一个方法用于询问代理在找不到缓存情况下,是否根据url下载图片.默认返回为yes.如果返回为NO,缓存中没有查找到也不下载
- 第二个方法用于询问代理是当下载出现错误的时候是否将
URL
添加到failedURLs
中,默认为yes
图片加载过程
目前图片加载主要是用到分类,以UIImageView+WebCache
为例子加载网络图片主要是调用sd_setImageWithURL
方法,而这些方法最终都会调用到SDWebImageManager
的- (nullable SDWebImageCombinedOperation *)loadImageWithURL:(nullable NSURL *)url options:(SDWebImageOptions)options progress:(nullable SDImageLoaderProgressBlock)progressBlock completed:(nonnull SDInternalCompletionBlock)completedBlock
详细的加载过程如下
- 判断传入
url
的合法性,如果是字符串将其转换成NSURL
,如果不存在则将url安置为nil - 判断是否为失败过得URL
[self.failedURLs containsObject:url]
- 如果URL的字符串长度为0,或者该url请求失败过,且传入的options不是
SDWebImageRetryFailed
,返回错误 (options & SDWebImageRetryFailed) - 创建
SDWebImageCombinedOperation *operation
操作,并将其加入到当前运行的所有操作中[self.runningOperations addObject:operation];
> 两个核心概念:queue(队列)、Operation(操作) - 判断options是不是
SDWebImageFromLoaderOnly
.如果是直接跳转到下载步骤.如果不是根据url
拿到缓存的key
- 根据拿到的key在
SDImageCache
中查找缓存 - 如果有缓存成功回调,没有缓存跳转到下载步骤
- 如果缓存中没有找到,且同事满足以下3中情况则使用
SDImageLoader
下载
* options不是SDWebImageFromCacheOnly
* 不存在缓存图片或者options为SDWebImageRefreshCached
* SDWebImageManager中的代理 [self.delegate imageManager:self shouldDownloadImageForURL:url]为yes - 下载报错,将url添加到全局的
failedURLs
,返回错误 - 下载成功,将url从全局的
failedURLs
中移除,然后对图片进行缓存(内存和磁盘),然后成功返回.图片加载完成.
图片缓存
结构
SDImageCache
单例中主包含是SDImageCacheConfig
、SDMemoryCache
、SDDiskCache
三个模块
-
SDImageCacheConfig(单利)
:用来设置缓存的策略。如磁盘缓存大小(无限制)、内存缓存大小(无限制)、磁盘缓存时间(默认7天)、是否允许内存缓存、是否进入后台自动清除过期磁盘数据等 -
SDMemoryCache
: SDMemoryCache继承自NSCache,对内存缓存进行增、删、查。 -
SDDiskCache
: 磁盘缓存。diskCache中可以根据key来设置和读取磁盘数据,删除过期数据等。key是url+其他image额外的信息进行16位的MD5加密。
缓存清理时机
-
UIApplicationWillTerminateNotification
程序将要杀死时候,会调用deleteOldFilesWithCompletionBlock
,通过diskCache来清理磁盘缓存 -
UIApplicationDidEnterBackgroundNotification
程序进入后台,也会调用deleteOldFilesWithCompletionBlock
清理磁盘缓存 -
didReceiveMemoryWarning
监听内存警告,收到警告后清理内存缓存
清理磁盘的策略
- 先获取当前磁盘目录,遍历当前磁盘目录URL,查找磁盘数据中所有修改日期超过最大磁盘缓存时间的数据,清除超时数据
- 在遍历磁盘数据的时候,更新未超时的本地磁盘占用大小;如果最后超过了规定的磁盘占用大小,对磁盘文件的修改时间进行排序,然后for循环中移除最老的数据,直到占用磁盘总大小小于设置的磁盘最大占用
参考链接
下载模块 SDwebImageDownloader
该模块主要包含SDWebImageDownloaderConfig
和SDwebImageDownloader
-
SDWebImageDownloaderConfig
下载的配置,包括最大并发(默认6个)、超时时间(15s)等 -
SDwebImageDownloader
进行下载
下载会对调用一下方法
- (nullable SDWebImageDownloadToken *)downloadImageWithURL:(nullable NSURL *)url
options:(SDWebImageDownloaderOptions)options
context:(nullable SDWebImageContext *)context
progress:(nullable SDWebImageDownloaderProgressBlock)progressBlock
completed:(nullable SDWebImageDownloaderCompletedBlock)completedBlock;