自制一个指定容量缓存,并实现最近使用的最后删除

需求

  • 实现一个缓存key-value结构,并设定容量最大值,
  • 当put进去的时候,如果超过最大容量,则将最早放进去的删除
  • 当get的时候,返回key值,并将key放到后面(表示最近使用过,最后删除)

上代码

java 复制代码
import java.util.Deque;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.Map;

/**
 * 实现一个缓存key-value结构,并设定容量最大值,
 * 当put进去的时候,如果超过最大容量,则将最早放进去的删除
 * 当get的时候,返回key值,并将key放到后面(表示最近使用过,最后删除)
 */
public class LRUCache {
        private Map<String, Object> cache;
	    private Deque<String> deque;
	    private int capacity;

        public LRUCache(int capacity) {
	        this.capacity = capacity;
	        this.cache = new HashMap<>();
	        this.deque = new LinkedList<>();
	    }

        public Object get(String key) {
	        if (!cache.containsKey(key)) {
	            return -1;
	        }
	        deque.remove(key); // 删掉原key,将其移到队列尾
	        deque.offerLast(key);
	        return cache.get(key);
	    }

        public void put(String key, Object value) {
	        if (cache.containsKey(key)) {
	            deque.remove(key); // 删掉原key,将其移到队列尾
	        } else if (cache.size() >= capacity) {
	            String removed = deque.pollFirst(); // 移除队首(最久未使用)
	            cache.remove(removed);
	        }
	        cache.put(key, value);
	        deque.offerLast(key);
	    }

    @Override
    public String toString() {
        return "LRUCache{" +
                "cache=" + cache +
                ", deque=" + deque +
                ", capacity=" + capacity +
                '}';
    }
}

测试效果

java 复制代码
public class LRUCacheTest {
    public static void main(String[] args) {
        LRUCache lruCache = new LRUCache(5);
        lruCache.put("aa", "aa");
        lruCache.put("bb", "bb");
        lruCache.put("cc", "cc");
        lruCache.put("dd", "dd");
        lruCache.put("ee", "ee");
        System.out.println(lruCache);
        lruCache.get("aa");
        System.out.println(lruCache);
        lruCache.put("ff", "ff");
        System.out.println(lruCache);
        
    }
}

结果:

相关推荐
Lilixy.18231 小时前
【Java-解决精度丢失】
java·开发语言·apache
weixin_486681141 小时前
C++系列-STL容器之queue
开发语言·c++
DBdoctor官方1 小时前
MySQL内部临时表(Using temporary)案例详解及优化解决方法
java·开发语言·数据库·sql·mysql·临时表·内部临时表
martian6653 小时前
学懂C++(四十四):C++ 自定义内存管理的深入解析:内存池与自定义分配器
开发语言·c++·内存池·自定义内存管理
汇匠源3 小时前
零工市场Java源码,支持私有化部署?
java·开发语言
社恐小美~3 小时前
C语言入门基础知识(持续更新中)
c语言·开发语言·汇编
国中之林3 小时前
【C++ Primer Plus习题】7.7
开发语言·c++·学习·刷题
hola1738414393 小时前
【无标题】
开发语言·javascript·node.js
杨侨治3 小时前
Spring&AOP&Spring事物管理
java·开发语言·数据库·笔记·spring·mybatis·java基础
hhhcbw3 小时前
C++宏展开
开发语言·c++·windows