LruCache & DiskLru简介

LRU:近期最少使用算法,当缓存满时,优先淘汰近期最少使用的缓存对象。实现方式有两种LruCache和DiskLruCache。

强引用,软引用,弱引用的区别
  • 强引用:直接的对象引用
  • 软引用:当一个对象只有软引用存在时,系统内存不足此时对象会被gc回收
  • 弱引用:当一个对象只有弱引用存在时,此对象会随时被gc回收

LruCache:
1.1简介
LruCache是一个泛型类,从图1.1中可以看到它内部采用了LinkedHashMap以强引用(直接引用对象)的形式存储外界的缓存对象,其提供了get和put方法,当缓存满时,LruCache会移除近期最少使用的缓存对象,在添加新的缓存对象。

1.2LruCache的使用

int maxMemory = (int)(Runtime.getRuntime().maxMemory() / 1024);// kB
int cacheSize = maxMemory / 8;
LruCache mLruCache = new LruCache(cacheSize){
        @Override
        protected int sizeOf(String key, Bitmap value) {
           return  value.getRowBytes() * value.getHeight() /1024;
        }
};

sizeOf方法的作用是计算缓存对象的大小,这里大小的单位要一致。总容量大小为当前进程可用内存的1/8,单位为kb,而sizeOf方法则完成了Bitmap对象大小的计算,之所以除以1024也是为了将其单位转换为kb。一些情况下,还需要重写LruCache的entryRemoved方法,当LruCache移除旧缓存对象的时候会调用entryRemoved方法,因此可以在entryRemoved方法中完成一些资源的回收。
从LruCache中添加一个缓存对象
mLruCache.put(key,bitmap)
得到缓存对象
mLruCache.get(key)
2.1DiskLruCache简介
它主要用于硬盘存储,通过将缓存对象写入文件系统实现缓存的效果。他不属于Android SDK中的一部分
2.2DiskLruCache的使用
2.2.1 DiskLruCache对象的创建
public static DiskLruCache open(File directory, int appVersion, int valueCount, long maxSize)
参数一:存储路径
参数二:版本号
参数三:单个节点对应的数据个数,一般设为1即可。
参数四:最大缓存值

private static final long DISK_CACHE_SIZE  = 1024 * 1024 * 50;
                File diskCacheDir = getDiskCacheDir(context, "bitmap");
                if(!diskCacheDir.exists()) {
                    diskCacheDir.mkdirs();
                }
                DiskLruCache mDiskLruCache = DiskLruCache.open(diskCacheDir,1,1,DISK_CACHE_SIZE);

2.2.2 缓存添加
DiskLruCache 的缓存添加操作是通过Editor完成的,Editor缓存对象的编辑对象。

String key = hashKeyFormUrl(url);
DiskLruCache.Editor editor = mDiskLruCache.edit();
if(editor!=null){
    OutputStream outputStream = editor.newOutputStream(DISK_CACHE_INDEX);
}

你可能感兴趣的:(LruCache & DiskLru简介)