android错误自动跳转缓存的活动中,Android 缓存机制(一)

本文介绍了相册图片预取的缓存策略,使用了LruCache实现硬引用缓存,SoftReference处理软引用,并结合context.getCachedDir()进行外部文件缓存。当内存不足时,优先清理最不常用的图片。策略涉及缓存当前、前一张和后一张图片,确保流畅用户体验。
摘要由CSDN通过智能技术生成

相册图片预取缓存策略是内存缓存(硬引用LruCache、软引用SoftReference)、外部文件缓存(context.getCachedDir()),缓存中取不到的情况下再向服务端请求下载图片。同时缓存三张图片(当前预览的这张,前一张以及后一张)。

内存缓存

//需要导入外部jar文件 android-support-v4.jar

import android.support.v4.util.LruCache;

//开辟8M硬缓存空间

private final int hardCachedSize = 8*1024*1024;

//hard cache

private final LruCache sHardBitmapCache = new LruCache(hardCachedSize){

@Override

public int sizeOf(String key, Bitmap value){

return value.getRowBytes() * value.getHeight();

}

@Override

protected void entryRemoved(boolean evicted, String key, Bitmap oldValue, Bitmap newValue){

Log.v("tag", "hard cache is full , push to soft cache");

//硬引用缓存区满,将一个最不经常使用的oldvalue推入到软引用缓存区

sSoftBitmapCahe.put(key, new SoftReference(oldValue));

}

}

//软引用

private static final int SOFT_CACHE_CAPACITY = 40;

private final static LinkedHashMap> sSoftBitmapCache =

new  LinkedHashMao>(SOFT_CACHE_CAPACITY, 0.75f, true){

@Override

public SoftReference put(String key, SoftReference value){

return super.input(key, value);

}

@Override

protected boolean removeEldestEntry(LinkedHashMap.Entry> eldest){

if(size() > SOFT_CACHE_CAPACITY){

Log.v("tag", "Soft Reference limit , purge one");

return true;

}

return false;

}

}

//缓存bitmap

public boolean putBitmap(String key, Bitmap bitmap){

if(bitmap != null){

synchronized(sHardBitmapCache){

sHardBitmapCache.put(key, bitmap);

}

return true;

}

return false;

}

//从缓存中获取bitmap

public Bitmap getBitmap(String key){

synchronized(sHardBitmapCache){

final Bitmap bitmap = sHardBitmapCache.get(key);

if(bitmap != null)

return bitmap;

}

//硬引用缓存区间中读取失败,从软引用缓存区间读取

synchronized(sSoftBitmapCache){

SoftReference bitmapReference = sSoftBtimapCache.get(key);

if(bitmapReference != null){

final Bitmap bitmap2 = bitmapReference.get();

if(bitmap2 != null)

return bitmap2;

else{

Log.v("tag", "soft reference 已经被回收");

sSoftBitmapCache.remove(key);

}

}

}

return null;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值