Android 缓存机制(一)
来源:互联网 发布:幽默淘宝店铺公告范文 编辑:程序博客网 时间:2024/05/16 04:31
相册图片预取缓存策略是内存缓存(硬引用LruCache、软引用SoftReference<Bitmap>)、外部文件缓存(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<String, Bitmap> sHardBitmapCache = new LruCache<String, Bitmap>(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<Bitmap>(oldValue));
}
}
//软引用
private static final int SOFT_CACHE_CAPACITY = 40;
private final static LinkedHashMap<String, SoftReference<Bitmap>> sSoftBitmapCache =
new LinkedHashMao<String, SoftReference<Bitmap>>(SOFT_CACHE_CAPACITY, 0.75f, true){
@Override
public SoftReference<Bitmap> put(String key, SoftReference<Bitmap> value){
return super.input(key, value);
}
@Override
protected boolean removeEldestEntry(LinkedHashMap.Entry<Stirng, SoftReference<Bitmap>> 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<Bitmap> 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;
}
- Android 缓存机制(一)
- Android 缓存机制(一)
- Android 缓存原理(一)----ListView缓存机制
- hibernate缓存机制(一)
- iOS缓存机制(一)
- iOS缓存机制(一)
- Android 缓存机制(二)
- Android 缓存机制(三)
- Android 缓存机制(二)
- 浏览器缓存机制浅析(一)
- 缓存机制Cache ARC算法(一)
- hibernate的缓存机制(一)
- MySQL缓存机制详解(一)
- Mybatis的缓存机制(一)
- Android 缓存机制代码(软引用)
- Android图片缓存机制(Caching Bitmaps)
- android缓存机制
- Android webView缓存机制
- Solr的SolrCloud与Master-slave主从模式对比
- Java Eclipse Tomcat MySql开发javaweb项目环境搭建
- hdu1007Quoit Design
- padding 内边距
- 归并排序
- Android 缓存机制(一)
- 为什么使用泛型
- |洛谷|搜索|P2089 烤鸡
- combiner partitioner
- java基础篇(一)——认识java
- Quartz学习——Quartz 学习的博客地址记录
- HDU 1242
- Java虚拟机——JVM
- |洛谷|搜索|P2666 Bessie的秘密牧场