memorycache java_内存缓存工具类MemoryCache

MemoryCache是用于内存缓存的Java类,利用LinkedHashMap实现LRU(最近最少使用)策略。它限制了缓存占用的最大堆内存,并在超出限制时清理最不常使用的元素。类提供了获取、添加、检查大小以及清除缓存的方法,同时计算Bitmap对象的字节数以精确控制内存使用。
摘要由CSDN通过智能技术生成

package com.qianfeng.assistant.modules.other.utils;

import android.graphics.Bitmap;

import java.util.Collections;

import java.util.Iterator;

import java.util.LinkedHashMap;

import java.util.Map;

/**

* 内存缓存

* @date : 15/12/9.

*/

public class MemoryCache {

private static final String TAG = "MemoryCache";

// 放入缓存时是个同步操作

// LinkedHashMap构造方法的最后一个参数true代表这个map里的元素将按照最近使用次数由少到多排列,即LRU

// 这样的好处是如果要将缓存中的元素替换,则先遍历出最近最少使用的元素来替换以提高效率

private Map cache = Collections

.synchronizedMap(new LinkedHashMap(20, 1.5f, true));

// 缓存中图片所占用的字节,初始0,将通过此变量严格控制缓存所占用的堆内存

private long size = 0;// current allocated size

// 缓存只能占用的最大堆内存

private long limit = 1000000;// max memory in bytes

public MemoryCache() {

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值