采用LRU算法的MemoryCache缓存实现

//本例采用的是LRU算法,先看看MemoryCache的实现
public class MemoryCache {
        private static final String TAG = "MemoryCache";
        // 放入缓存时是个同步操作
        // LinkedHashMap构造方法的最后一个参数true代表这个map里的元素将按照最近使用次数由少到多排列,即LRU
        // 这样的好处是如果要将缓存中的元素替换,则先遍历出最近最少使用的元素来替换以提高效率
        private Map<String, Bitmap> cache = Collections
                        .synchronizedMap(new LinkedHashMap<String, Bitmap>(10, 1.5f, true));
        // 缓存中图片所占用的字节,初始0,将通过此变量严格控制缓存所占用的堆内存
        private long size = 0;// current allocated size
        // 缓存只能占用的最大堆内存
        private long limit = 1000000;// max memory in bytes
         public MemoryCache() {
                // use 25% of available heap size
                setLimit(Runtime.getRuntime().maxMemory() / 10);
        }
        public void setLimit(long new_limit) {
                limit = new_limit;
                Log.i(TAG, "MemoryCache will use up to " + limit / 1024. / 1024. + "MB");
        }
        public Bitmap get(String id) {
                try {
                        if (!cache.containsKey(id))
                                return null;
                        return cache.get(id);
                } catch (NullPointerException ex) {
                        return null;
                }
        }
        public void put(String id, Bitmap bitmap) {
                try {
                        if (cache.containsKey(id))
                                size -= getSizeInBytes(cache.get(id));
                        cache.put(id, bitmap);
                        size += getSizeInBytes(bitmap);
                        checkSize();
                } catch (Throwable th) {
                        th.printStackTrace();
                }
        }
         /**
         * 严格控制堆内存,如果超过将首先替换最近最少使用的那个图片缓存
         * 
         */
        private void checkSize() {
                Log.i(TAG, "cache size=" + size + " length=" + cache.size());
                if (size > limit) {
                        // 先遍历最近最少使用的元素
                        Iterator<Entry<String, Bitmap>> iter = cache.entrySet().iterator();
                        while (iter.hasNext()) {
                                Entry<String, Bitmap> entry = iter.next();
                                size -= getSizeInBytes(entry.getValue());
                                iter.remove();
                                if (size <= limit)
                                        break;
                        }
                        Log.i(TAG, "Clean cache. New size " + cache.size());
                }
        }
        public void clear() {
          cache.clear();
        }
 
        /**
         * 图片占用的内存
             * 
            * @return
         */
        long getSizeInBytes(Bitmap bitmap) {
                if (bitmap == null)
                        return 0;
                return bitmap.getRowBytes() * bitmap.getHeight();
        }
}

 

转载于:https://my.oschina.net/vijoz/blog/692569

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值