zoukankan      html  css  js  c++  java
  • 使用LinkedHashMap实现一个简易的LRU缓存

    方法1 :leetcode 解法

    方法2:

    package arithmetic;
    
    import java.util.LinkedHashMap;
    import java.util.Map;
    
    /**
     * @Author yuanjingkun
     * @create 2020/4/29 17:43
     */
    public class LRUCache<K, V> extends LinkedHashMap<K, V> {
        private int cacheSize;
    
        public LRUCache(int cacheSize) {
            super(16, 0.75f, true);
            this.cacheSize = cacheSize;
        }
    
        @Override
        protected boolean removeEldestEntry(Map.Entry<K, V> eldest) {
            return size() > cacheSize;
        }
    
        public static void main(String[] args) {
            LRUCache<String, String> lru = new LRUCache<>(5);
            lru.put("球员1", "杜兰特");
            lru.put("球员2", "表妹");
            lru.put("球员3", "库里");
            System.out.println(lru);
            lru.get("球员1");
            System.out.println(lru);
            lru.put("球员4", "一哥");
            lru.put("球员5", "汤姆");
            System.out.println(lru);
            lru.put("球员6", "格林");
            System.out.println(lru);
        }
    
    
    }

    方法3:https://blog.csdn.net/Apeopl/article/details/90137398

    import java.util.LinkedHashMap;
    import java.util.Map;
    import java.util.Set;
    
    public class SimpleLRUCache<K, V> {
    
        private final int MAX_CACHE_SIZE;
        private final float DEFAULT_LOAD_FACTORY = 0.75f;
    
        LinkedHashMap<K, V> map;
    
        public SimpleLRUCache(int cacheSize) {
            MAX_CACHE_SIZE = cacheSize;
            int capacity = (int)Math.ceil(MAX_CACHE_SIZE / DEFAULT_LOAD_FACTORY) + 1;
            map = new LinkedHashMap<K, V>(capacity, DEFAULT_LOAD_FACTORY, true) {
                private static final long serialVersionUID = 1L;
                @Override
                protected boolean removeEldestEntry(Map.Entry<K, V> eldest) {
                    return size() > MAX_CACHE_SIZE;
                }
            };
        }
    
        public synchronized void put(K key, V value) {
            map.put(key, value);
        }
        public synchronized V get(K key) {
            return map.get(key);
        }
        public synchronized void remove(K key) {
            map.remove(key);
        }
        public synchronized Set<Map.Entry<K, V>> getAll() {
            return map.entrySet();
        }
        @Override
        public String toString() {
            StringBuilder stringBuilder = new StringBuilder();
            for (Map.Entry<K, V> entry : map.entrySet()) {
                stringBuilder.append(String.format("%s: %s  ", entry.getKey(), entry.getValue()));
            }
            return stringBuilder.toString();
        }
    
        public static void main(String[] args) {
            SimpleLRUCache<String, String> lru = new SimpleLRUCache<>(5);
            lru.put("球员1", "杜兰特");
            lru.put("球员2", "表妹");
            lru.put("球员3", "库里");
            System.out.println(lru);
            lru.get("球员1");
            System.out.println(lru);
            lru.put("球员4", "一哥");
            lru.put("球员5", "汤姆");
            System.out.println(lru);
            lru.put("球员6", "格林");
            System.out.println(lru);
        }
    }
  • 相关阅读:
    TreeSet类的排序问题
    TreeSet()详解
    css中vertical-align垂直居中的认识
    CSS3 float深入理解浮动资料整理
    层叠顺序与层叠上下文
    jquery.zclip轻量级复制失效问题
    文章转载利用border、transparent实现微风
    转载利用线性渐变实现晴天、多云特效
    转载利用伪元素单个颜色实现 hover 和 active 时的明暗变化效果
    MUI-最接近原生App体验的前端框架
  • 原文地址:https://www.cnblogs.com/thiaoqueen/p/12796769.html
Copyright © 2011-2022 走看看