当前位置: 移动技术网 > IT编程>移动开发>IOS > swift3.0网络图片缓存原理简析

swift3.0网络图片缓存原理简析

2019年07月24日  | 移动技术网IT编程  | 我要评论

地理等高线,素颜格格 古月,平乡二手房

一. 缓存原理

图片缓存原理原理是,如内存没图片,去磁盘找,若磁盘也没有,则根据url去下载,然后缓存到内存和磁盘中,简单易用

缓存的目录结构如下图:

 //存储图片的文件夹
 var ljfilepath:string =nshomedirectory() +"/documents/"+"ljimagecache/"

二. 图片名称处理

为了确保缓存下来的图片的唯一性,所以此处采用图片的url+md5=唯一标识符,来存储图片,如上图图片的名称。

创建一个sting+md5.swift字符串分类文件(同时此处需要创建一个bridge.h桥接文件,引入这个头文件

#import <commoncrypto/commondigest.h>,md5加密方法需要使用的文件)

1.bridge.h桥接文件如下:

#ifndef bridge_h 
#define bridge_h 
 
#import <commoncrypto/commondigest.h> 
 
#endif /* bridge_h */ 

2. sting+md5.swift文件如下

import foundation 
 
extension string { 
  var md5 : string{ 
    let str = self.cstring(using: string.encoding.utf8) 
    let strlen = cc_long(self.lengthofbytes(using: string.encoding.utf8)) 
    let digestlen = int(cc_md5_digest_length) 
    let result = unsafemutablepointer<cunsignedchar>.allocate(capacity: digestlen) 
     
    cc_md5(str!, strlen, result) 
     
    let hash = nsmutablestring() 
    for i in 0 ..< digestlen { 
      hash.appendformat("%02x", result[i]) 
    } 
    result.deinitialize() 
     
    return string(format: hash as string) 
  } 
} 

三.图片缓存和读取

1. 图片缓存

func urlsession(_ session: urlsession, task: urlsessiontask, didcompletewitherror error: error?) 
  { 
    if ljcallbackclosure != nil ,let data = self.responsedata{ 
      weak var weakself : ljopreationmanager? = self 
      dispatchqueue.main.async 
      { 
        print("urlsessiondatadelegate----数据下载完毕") 
         
        ljcachedatamanage.shared.setmemorycache((task.currentrequest?.url?.absolutestring)!,data as data) 
         
        //图片缓存,根据唯一的url来作为存储数据的名称 
        let a = ljfilemanager.shared.writefile((task.currentrequest?.url?.absolutestring)!,data as nsdata) 
         
        print("-----写入文件成功\(a)") 
         
        //将接收的数据结果回调到前台,用于进度展示 
        weakself?.ljcallbackclosure!(data as data ,nil) 
      } 
    } 
  } 

2.图片读取

public func retrieveimage(_ ljurl: string, _ ljcallback: @escaping opreationclosure){ 
     
    if ljurl != "" { 
       
      if ljfilemanager.shared.readfilefromcache(ljurl) != nil { 
        //将接收的数据结果回调到前台,用于进度展示 
        print("获取的是disk缓存数据哦完毕") 
        ljcallback(ljfilemanager.shared.readfilefromcache(ljurl) as! data,nil) 
      } 
      //首先取缓存数据,没取到的话,直接下载 
     else if ljcachedatamanage.shared.getmemorycache(ljurl) != nil { 
        //将接收的数据结果回调到前台,用于进度展示 
        print("获取的是memory缓存数据哦完毕") 
        ljcallback(ljcachedatamanage.shared.getmemorycache(ljurl) ,nil) 
      } 
      else 
      { 
       _ = self.requestwebbyurl(ljurl, ljcallback) 
      } 
    } 
  } 

3. 读写磁盘文件

(1)存储的时候给url进行md5加密得到filename.md5文件名称,然后存储,如上面的截图

(2)读取文件时,给url进行md5加密得到path.md5的,然后获取文件数据

/* 写文件 
  filename: 文件名称 
  data: 数据data 
*/ 
func writefile(_ filename:string , _ data:nsdata) -> bool{ 
   
  //let filepath:string = nshomedirectory() + "/documents/" + filename.md5 
  //return data.write(tofile: filepath, atomically: true) 
  guard self.isexistfiledir(ljfilepath) else{ 
    return false 
  } 
   
  guard let filepath : string = ljfilepath + filename.md5 else{ 
    return false 
  } 
  return data.write(tofile: filepath, atomically: true) 
} 
 
//读取文件 -(根据路径) 
func readfilefromcache(_ path:string) -> nsdata?{ 
   
  if self.isexistfiledir(ljfilepath) 
  { 
    let ljpatch = ljfilepath + path.md5 
    var result:nsdata? 
    do{ 
      result = try nsdata(contentsoffile: ljpatch, options: data.readingoptions.uncached) 
    }catch{ 
      return nil 
    } 
    return result 
  } 
  return nil 
} 

4.读写内存文件

import foundation 
 
class ljcachedatamanage: nsobject{ 
   
  //单例 
  public static let shared = ljcachedatamanage() 
   
  // public var diskcache = 
   
  //缓存的数据 
  public var memorycache = dictionary<string, data>() 
   
  //返回缓存的数据 
  func getmemorycache(_ urlstr : string) -> data? { 
     
    print("返回缓存的数据------\(memorycache[urlstr] ?? nil)") 
    return (memorycache[urlstr] ?? nil) 
  } 
   
  //设置缓存值 
  func setmemorycache(_ urlstr : string, _ data : data){ 
    if urlstr != "", data != nil { 
      memorycache[urlstr] = data 
    } 
  } 
} 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

  • ios uicollectionview实现横向滚动

    现在使用卡片效果的app很多,之前公司让实现一种卡片效果,就写了一篇关于实现卡片的文章。文章最后附有demo实现上我选择了使用uicollectionview ... [阅读全文]
  • iOS UICollectionView实现横向滑动

    本文实例为大家分享了ios uicollectionview实现横向滑动的具体代码,供大家参考,具体内容如下uicollectionview的横向滚动,目前我使... [阅读全文]
  • iOS13适配深色模式(Dark Mode)的实现

    iOS13适配深色模式(Dark Mode)的实现

    好像大概也许是一年前, mac os系统发布了深色模式外观, 看着挺刺激, 时至今日用着也还挺爽的终于, 随着iphone11等新手机的发售, ios 13系统... [阅读全文]
  • ios 使用xcode11 新建项目工程的步骤详解

    ios 使用xcode11 新建项目工程的步骤详解

    xcode11新建项目工程,新增了scenedelegate这个类,转而将原appdelegate负责的对ui生命周期的处理担子接了过来。故此可以理解为:ios... [阅读全文]
  • iOS实现转盘效果

    本文实例为大家分享了ios实现转盘效果的具体代码,供大家参考,具体内容如下demo下载地址: ios转盘效果功能:实现了常用的ios转盘效果,轮盘抽奖效果的实现... [阅读全文]
  • iOS开发实现转盘功能

    本文实例为大家分享了ios实现转盘功能的具体代码,供大家参考,具体内容如下今天给同学们讲解一下一个转盘选号的功能,直接上代码直接看viewcontroller#... [阅读全文]
  • iOS实现轮盘动态效果

    本文实例为大家分享了ios实现轮盘动态效果的具体代码,供大家参考,具体内容如下一个常用的绘图,主要用来打分之类的动画,效果如下。主要是ios的绘图和动画,本来想... [阅读全文]
  • iOS实现九宫格连线手势解锁

    本文实例为大家分享了ios实现九宫格连线手势解锁的具体代码,供大家参考,具体内容如下demo下载地址:效果图:核心代码://// clockview.m// 手... [阅读全文]
  • iOS实现卡片堆叠效果

    本文实例为大家分享了ios实现卡片堆叠效果的具体代码,供大家参考,具体内容如下如图,这就是最终效果。去年安卓5.0发布的时候,当我看到安卓全新的material... [阅读全文]
  • iOS利用余弦函数实现卡片浏览工具

    iOS利用余弦函数实现卡片浏览工具

    本文实例为大家分享了ios利用余弦函数实现卡片浏览工具的具体代码,供大家参考,具体内容如下一、实现效果通过拖拽屏幕实现卡片移动,左右两侧的卡片随着拖动变小,中间... [阅读全文]
验证码:
移动技术网