基于LinkedHashMap手写LRU算法
采用LinkedHashMap的按照访问顺序来进行排序,最近访问的放在头部,最老访问的放在尾部的原理,当数据量大于指定的缓存个数的时候,就自动删除最老的数据。
import java.util.LinkedHashMap; import java.util.Map; public class LRUCache<K, V> extends LinkedHashMap<K, V> { private final int CACHE_SIZE; /** * 传递进来最多能缓存多少数据 * @param cacheSize 缓存大小 */ public LRUCache(int cacheSize) { // 设置一个hashmap的初始大小,最后的true 表示让 linkedHashMap按照访问顺序来进行排序,最近访问的放在头部,最老访问的放在尾部。 super((int) Math.ceil(cacheSize / 0.75) + 1, 0.75f, true); CACHE_SIZE = cacheSize; } @Override protected boolean removeEldestEntry(Map.Entry<K, V> eldest) { // 当map中的数据量大于指定的缓存个数的时候,就自动删除最老的数据。 return size() > CACHE_SIZE; } }