• SDWebImage的实现原理


    一、SDWebImage库的作用:

    它主要是通过对UIImageView的类别(分类)扩展来实现异步加载替换图片的工作。

    二、主要用到的对象:

    1、UIImageView + WebCache :入口封装,实现读取图片完成后的回调工作;

    2、SDWebImageManager:

    • 记录那些图片正在读取,对图片进行管理的中转站;
    • 调用SDImageCache向下层读取Cache,调用SDWebImageDownloader向网络读取对象;
    • 实现SDImageCache 和 SDWebImageDownloader的回调。

    3、SDImageCache: 根据URL的MD5摘要对图片进行存储和读取 (实现存在内存中或者存在硬盘上)实现图片和内存清理工作。

    • SDImageCache分两个部分,一个是内存层面的,一个是硬盘层面的。
    • 内存层面:相当是个缓存器,以Key-Value的形式存储图片。当内存不够的时候会清除所有缓存图片。用搜索文件系统的方式做管理,文件替换方式是以时间为单位,剔除时间大于一周的图片文件。
    • 当SDWebImageManager向SDImageCache要资源时,先搜索内存层面的数据,如果有直接返回,没有的话去访问磁盘,将图片从磁盘读取出来,然后做Decoder,将图片对象放到内存层面做备份,再返回调用层。

    4、SDWebImageDownloader:根据URL向网路读取数据(实现部分读取和全部读取后再通知回调两种方式)。

    5、SDWebImageDecoder: 对图片进行异步解压操作。

    • 由于UIImage的imageWithData函数是每次画图的时候才将Data解压成ARGB的图像,所以在每次画图的时候,会有一个解压操作,这样效率很低,但是只有瞬时的内存需求。为了提高效率通过SDWebImageDecoder将包装在Data下的资源解压,然后画在另外一张图片上,这样这张新图片就不再需要重复解压了。这种做法是典型的空间换时间的做法。
  • 相关阅读:
    面试题之发散思维能力:如何用非常规方法求1+2+···+n
    优秀Python学习资源收集汇总(强烈推荐)
    JavaScript简洁继承机制实现(不使用prototype和new)
    JsRender for index 循环索引使用说明
    JsRender for object 语法说明
    pasteimg浏览器中粘贴图片jQuery插件
    西安电子科技大学泄漏信息
    移动端二维码弹出框,自适应屏幕尺寸
    服务器端json数据文件分割合并解决方案
    html中a标签href属性的一个坑
  • 原文地址:https://www.cnblogs.com/zhaojian/p/5056591.html
Copyright © 2020-2023  润新知