LRU缓存就像你装破鞋的鞋柜,附实现攻略

22 篇文章 0 订阅
6 篇文章 0 订阅
本文介绍了如何利用Java的LinkedHashMap实现一个简单的LRU缓存。LRU策略基于最近最少使用的数据优先淘汰,适用于热点数据场景。通过覆盖removeEldestEntry方法,当缓存达到最大容量时,会删除最不常使用的数据。注意在高并发环境下要考虑同步问题。
摘要由CSDN通过智能技术生成

今天我们讲一下怎么实现一个简单的最近最少使用(LRU)的缓存。

概念

LRU是Least Recently Used 的缩写,意为“最近最少使用”。

LRU缓存简单的说就是缓存一定量的数据,当超过设定的阈值时就把一些过期的数据删除掉。

举个生活中的例子,你有一堆鞋子,肯定是最新买的最喜欢穿的放在身边,鞋柜满了的话,如果你不是壕,扔鞋子也会先扔破鞋。

如图,把格子想想成你的鞋柜。一个格子只能放一双鞋子哦。

新数据插入到链表头部;(新鞋子放在最外边)

每当缓存命中(即缓存数据被访问),则将数据移到链表头部;(刚穿过的鞋子放在最外面)

当链表满的时候,将链表尾部的数据丢弃。(鞋柜满了,就需要忍痛扔破鞋)

当存在热点数据时,LRU的效率很好,但偶发性的、周期性的批量操作会导致LRU命中率急剧下降,缓存污染情况比较严重。

实现

Java里面实现LRU缓存通常有多种选择,一种是使用LinkedHashMap,一种是自己设计数据结构,使用链表+HashMap,灵活度更高的可以自定义使用方式。 搞Java的同学真是幸福,因为LinkedHashMap就是一个天生的LRU。

先来看一下LinkedHashMap的构造方法。

public LinkedHashMap(int initialCapacity,
float loadFactor,
boolean accessOrder) {
super(initialCapacity, loadFactor);
this.accessOrder = accessOrder;
}

注意accessOrder这个参数,为true使用访问顺序排序,false使用插入顺序排序。使用访问顺序排序,就是LRU。

当需要添加元素时,会调用removeEldestEntry方法,这里就是实现LRU元素过期机制的地方,默认的情况下removeEldestEntry方法只返回false表示元素永远不过期。

根据以上介绍,可以使用继承方式实现一个最简单的LRU.只需要覆盖removeEldestEntry方法。

public static class LRULinkedHashMap<K, V> extends LinkedHashMap<K, V> {
        private static final int  LRU_MAX_CAPACITY = 1024;
        public LRULinkedHashMap(int initialCapacity, float loadFactor) {
            super(initialCapacity, loadFactor, true);
        }
        /** 
         * @see java.util.LinkedHashMap#removeEldestEntry(java.util.Map.Entry)
         */
        @Override
        protected boolean removeEldestEntry(Entry<K, V> eldest) {
            if(size() > LRU_MAX_CAPACITY) {
                return true;
            }
            return false;
        }
    }

注意点

使用LRU要注意以下几点:

缓存的数据是否真正有热点数据

缓存的大小一定要限制,否则会有内存撑爆的危险

老生常谈,高并发下一定要注意LRU操作的同步

资料获取方式→点我

可关注我的B站账号→→→→B站账号

学习交流群→→→→交流群

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值