SDWebImage的一些注意点
删除缓存文件的两个方法
clearMemory/clearDisk
: 对应的clear方法- clearMemory: 清除当前内存中所有的缓存
- clearDisk: 删除磁盘缓存中的缓存文件夹, 然后在新建一个
clearMemory/clearDisk
: 清理所有的磁盘缓存先删除过期的文件, 然后计算剩余的缓存文件大小, 如果(currentSize > maxSize)就继续删除, 按照缓存文件的保存时间来删除, 先删除旧的文件, 直到(currentSize < maxSize)
// 这里建议翻一翻他们的源码, 可以多理解一些它的底层机制 if (self.maxCacheSize > 0 && currentCacheSize > self.maxCacheSize)
保存图片的默认过期时间:
一个星期
// 过期时间, 当图片国旗了就会有可能被删除 static const NSInteger kDefaultCacheMaxCacheAge = 60 * 60 * 24 * 7; // 1 week
内存缓存机制:
NSCache
- NSCache是通过键值对的方法来存储数据的
- NSCache的缓存, 并不是copy这个数据, 而是引用这个数据, 保证不被释放
- 当需求内存时, NSCache会自动释放引用的数据, 然后释放内存
- NSCache是线程安全的, 不同的线程可以访问统一块内存, 不必手动增加互斥锁
- 缓存成本和缓存文件数
totalCostLimit
: 缓存成本是一个单位的概念, 设置一个最大的缓存成本, 保存文件的时候为保存的文件设置单个缓存成本, 如果总成本超过最大的缓存成本, 就会自动释放旧的文件countLimit
: 缓存文件可以设置NSCache对象缓存多少个文件, 如果超过最大值, 就会自动释放之前保存的[self.cache setObject:data forKey:@(i) cost:1]
- 当自动清理缓存文件的时候, 会调用代理方法来监听缓存文件的删除
- (void)cache:(NSCache *)cache willEvictObject:(id)obj
最大并发数:
maxConcurrentOperationCount = 6
- 可以通过修改系统的文件来更改最大并发数
- 但是不建议修改, 避免同一时间过多的数据请求和加载, 对App造成很大的内存开销
队列中任务的执行方式:
SDWebImageDownloaderExecutionOrder
- 该属性是一个枚举值, 分为两种方式
SDWebImageDownloaderFIFOExecutionOrder
: 默认值, 任务执行方式为队列方式--先进先执行SDWebImageDownloaderLIFOExecutionOrder
: 任务执行方式为栈方式--后进先执行
默认的缓存路径:
~/Library/Caches/default/com.hackemist.SDWebImageCache.default/...
图片保存的名称处理方式:
- 将图片的URL进行MD5加密后得出的结果, 保存为图片名称
echo -n "url" | md5
GIF图片, 是根据ImageIO的原理来播放的
- 建议如果大家是在团队中负责的图片处理, 就去挖掘一下:
<ImageIO/ImageIO.h>
框架
- 建议如果大家是在团队中负责的图片处理, 就去挖掘一下:
如何判断图片的类型
- 得到图片的二进制数据的第一个字节, 就能判断出图片的类型
该框架的网络请求方式:
NSURLConnection加载Request
默认的请求超时时间:
downloadTimeout = 15.0 // 15秒后
该框架内部对内存警告的处理方式:
内部会监听系统发出的系统内存警告通知, 然后清理内存缓存
// 当监听到系统发出的内存警告通知时, 调用NSCache的removeAllObjects方法 [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(removeAllObjects) name:UIApplicationDidReceiveMemoryWarningNotification object:nil];
计算图片的成本(NSCache所需的属性):
FOUNDATION_STATIC_INLINE NSUInteger SDCacheCostForImage(UIImage *image) { return image.size.height * image.size.width * image.scale * image.scale; }
SDWebImage的黑名单机制
@property (strong, nonatomic) NSMutableSet *failedURLs
- 当一个图片的URL为错误的时候, 为了保证不重复请求这个错误的URL, SDWebImage添加了一个黑名单机制, 将失效的URL添加到这个黑名单中, 并且不会重复下载黑名单中的URL
原文地址:https://www.jianshu.com/p/277b688b0384