其他分享
首页 > 其他分享> > SDWebImage从小白到大师蜕变

SDWebImage从小白到大师蜕变

作者:互联网

简介

SDWebImage提供的简洁的获取远程URL图片的API;平时开发中使用最多场景就是列表中的cell中要显示远程图片的需求,在具体的实现中要避免加载图片造成的界面卡顿,列表卡顿等现象的出现;所以需要编码实现如下功能:

SDWebImage的框架结构

  SDWebImage的框架结构

SDWebImage的图片下载分类,只要一行代码就可以实现图片异步下载和缓存功能。

功能简介

  1. 一个添加了web图片加载和缓存管理的UIImageView分类
  2. 一个异步图片下载器
  3. 一个异步的内存加磁盘综合存储图片并且自动处理过期图片
  4. 支持动态gif图
    • 4.0 之前的动图效果并不是太好
    • 4.0 以后基于 FLAnimatedImage加载动图
  5. 支持webP格式的图片
  6. 后台图片解压处理
  7. 确保同样的图片url不会下载多次
  8. 确保伪造的图片url不会重复尝试下载
  9. 确保主线程不会阻塞

实现原理

  1. 架构图(UML 类图)
    架构图(UML 类图)
  1. 流程图(方法调用顺序图)
   

目录结构

相关类名与功能描述
  SDWebImageDownloader:是专门用来下载图片和优化图片加载的,跟缓存没有关系
  SDWebImageDownloaderOperation:继承于 NSOperation,用来处理下载任务的
  SDImageCache:用来处理内存缓存和磁盘缓存(可选)的,其中磁盘缓存是异步进行的,因此不会阻塞主线程
  SDWebImageManager:作为 UIImageView+WebCache 背后的默默付出者,主要功能是将图片下载(SDWebImageDownloader)和图片缓存(SDImageCache)两个独立的功能组合起来
  SDWebImageDecoder:图片解码器,用于图片下载完成后进行解码
  SDWebImagePrefetcher:预下载图片,方便后续使用,图片下载的优先级低,其内部由 SDWebImageManager :来处理图片下载和缓存
  UIView+WebCacheOperation:用来记录图片加载的 operation,方便需要时取消和移除图片加载的 operation
  UIImageView+WebCache:集成 SDWebImageManager 的图片下载和缓存功能到 UIImageView 的方法中,方便调用方的简单使用
  UIImageView+HighlightedWebCache:跟 UIImageView+WebCache 类似,也是包装了 SDWebImageManager,只不过是用于加载 highlighted 状态的图片
  UIButton+WebCache:跟 UIImageView+WebCache 类似,集成 SDWebImageManager 的图片下载和缓存功能到 UIButton 的方法中,方便调用方的简单使用
  MKAnnotationView+WebCache:跟 UIImageView+WebCache 类似
  NSData+ImageContentType:用于获取图片数据的格式(JPEG、PNG等)
  UIImage+GIF:用于加载 GIF 动图
  UIImage+MultiFormat:根据不同格式的二进制数据转成 UIImage 对象
  UIImage+WebP用于解码并加载 WebP 图片

 

工作流程

    工作流程

常见面试题

  1. 图片文件缓存的时间有多长:1周

_maxCacheAge = kDefaultCacheMaxCacheAge

  1. SDWebImage 的内存缓存是用什么实现的?

NSCache

  1. SDWebImage 的最大并发数是多少?
    maxConcurrentDownloads = 6
  1. SDWebImage 支持动图吗?GIF
1. #import <ImageIO/ImageIO.h>
2. [UIImage animatedImageWithImages:images duration:duration];
  1. SDWebImage是如何区分不同格式的图像的

    • 根据图像数据第一个字节来判断的!
    • PNG:压缩比没有JPG高,但是无损压缩,解压缩性能高,苹果推荐的图像格式!
    • JPG:压缩比最高的一种图片格式,有损压缩!最多使用的场景,照相机!解压缩的性能不好!
    • GIF:序列桢动图,特点:只支持256种颜色!最流行的时候在1998~1999,有专利的!

6.SDWebImage 缓存图片的名称是怎么确定的!


7.SDWebImage 的内存警告是如何处理的!

青山不改,绿水长流,后会有期,感谢每一位佳人的支持!

 

标签:缓存,蜕变,白到,图片下载,WebCache,内存,SDWebImage,图片
来源: https://www.cnblogs.com/mysweetAngleBaby/p/15645139.html