Android中提供了一种基本的缓存策略,即LRU(least recently used)。
基于该种策略,当存储空间用尽时,缓存会清除最近最少使用的对象。
LruCache的使用示例如下:
public class ImageCache {
//定义LruCache,指定其key和保存数据的类型
private LruCache<String, Bitmap> mImageCache;
ImageCache() {
//获取当前进程可以使用的内存大小,单位换算为KB
final int maxMemory = (int)(Runtime.getRuntime().maxMemory() / 1024);
//取总内存的1/4作为缓存
final int cacheSize = maxMemory / 4;
//初始化LruCache
mImageCache = new LruCache<String, Bitmap>(cacheSize) {
//定义每一个存储对象的大小
@Override
protected int sizeOf(String key, Bitmap bitmap) {
return bitmap.getRowBytes() * bitmap.getHeight() / 1024;
}
};
}
//获取数据
public Bitmap getBitmap(String url) {
return mImageCache.get(url);
}
//存储数据
public void putBitmap(String url, Bitmap bitmap) {
mImageCache.put(url, bitmap);
}
}
代码可以直接调用getBitmap和putBitmap接口,读取和存储数据。
其内部的缓存实现逻辑,由LruCache对象独立完成。