91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現一個LRU算法?

發布時間:2020-05-19 14:01:21 來源:網絡 閱讀:1473 作者:shayang88 欄目:編程語言

LRU就是Least recently used,最近最少使用,如果空間不足淘汰掉最近最少使用的數據。
實現方式可以有一下三種:

1、單鏈表

如何實現一個LRU算法?

實現原理:
1、插入:插入數據是最新的數據,直接插入到鏈表尾部
2、查找:查找到的數據移動到鏈表尾部,代表最新訪問。
3、刪除:鏈表頭代表最近最少使用,如果鏈表滿,則刪除鏈表頭數據

時間復雜度:O(n)

2、哈希表+雙向鏈表

如何實現一個LRU算法?

1、先后插入5個節點,每個節點在2個鏈表中。
2、黑色鏈表,代表哈希沖突之后的鏈表。
3、紅色鏈表,代表節點之間的順序。
4、每個節點,由4部分組成,分別是數據,黑色鏈表的next指針,紅色鏈表的pre指針和next指針。

查找:通過哈希表查找到,然后移動到雙向鏈表的尾部。
刪除:通過哈希表查找到,通過雙向鏈表拿到前驅節點,直接刪除即可。
插入:先看是否存在,如果存在移動到鏈表尾部,如果不存在,鏈表滿的話刪除頭節點,然后插入鏈表尾部,否則不滿,則直接插入鏈表尾部。

3、LinkedHashMap

LinkedHashMap繼承自HashMap,擁有HashMap的所有特性,同時LinkedHashMap增加了head和tail指針,用于實現雙向鏈表。

如何實現一個LRU算法?

1、LinkedHashMap默認的支持按照插入順序保存數據,新的數據插入雙向鏈表尾部。
如何實現一個LRU算法?
如何實現一個LRU算法?
2、構造方法支持按照訪問順序,最新訪問的數據放到雙向鏈表尾部。
如何實現一個LRU算法?
如何實現一個LRU算法?

4、如何實現LRU算法呢,自動刪除掉鏈表頭的過期數據?

LinkedHashMap默認是不會自動刪除鏈表頭節點數據的,我們需要覆蓋類的一個方法:removeEldestEntry

1、實現一個類LruLinkedMap繼承LinkedHashMap

package com.jane;

import java.util.LinkedHashMap;

public class LruLinkedMap<K,V> extends LinkedHashMap<K,V> {

    private int size;

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

    /**
     * @description 重寫LinkedHashMap中的removeEldestEntry方法,當LRU中元素多余6個時,
     *              刪除最不經常使用的元素
     */
    @Override
    protected boolean removeEldestEntry(java.util.Map.Entry<K, V> eldest) {
        if(size() > size){
            return true;
        }
        return false;
    }

}

2、啟動文件:

package com.jane;

import java.util.Map;

public class Main {

    public static void main(String[] args) {
        LruLinkedMap<String, String> ss = new LruLinkedMap(5, 0.75f, true);

        ss.put("1", "3");
        ss.put("2", "4");
        ss.put("3", "6");
        ss.put("4", "1");
        ss.put("5", "5");

        for(Map.Entry e: ss.entrySet()) {
            System.out.println(e.getKey());
        }
        System.out.println("---------------");

        ss.get("1");

        for(Map.Entry e: ss.entrySet()) {
            System.out.println(e.getKey());
        }
        System.out.println("---------------");
        ss.put("7", "10");

        for(Map.Entry e: ss.entrySet()) {
            System.out.println(e.getKey());
        }
    }
}

3、結果:
如何實現一個LRU算法?

這樣LRU就輕松的實現了。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

城市| 鹤庆县| 鹰潭市| 河源市| 老河口市| 南华县| 佛冈县| 沅江市| 洞口县| 九龙城区| 电白县| 务川| 华阴市| 东乡族自治县| 宁武县| 佛山市| 拜泉县| 大丰市| 白银市| 灵璧县| 翁牛特旗| 军事| 海城市| 普兰店市| 泾源县| 锡林浩特市| 鄂托克旗| 东乌| 高唐县| 滕州市| 东光县| 香港| 梁河县| 吉木萨尔县| 开平市| 阿鲁科尔沁旗| 大关县| 哈尔滨市| 自贡市| 兰考县| 图木舒克市|