码迷,mamicode.com
首页 > Web开发 > 详细

SDWebImage的实现原理

时间:2015-12-18 13:03:30      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:

一、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下的资源解压,然后画在另外一张图片上,这样这张新图片就不再需要重复解压了。这种做法是典型的空间换时间的做法。

 

SDWebImage的实现原理

标签:

原文地址:http://www.cnblogs.com/zhaojian/p/5056591.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!