国产成人毛片视频|星空传媒久草视频|欧美激情草久视频|久久久久女女|久操超碰在线播放|亚洲强奸一区二区|五月天丁香社区在线|色婷婷成人丁香网|午夜欧美6666|纯肉无码91视频

java實(shí)現(xiàn)lru算法 android里面lrucache算法為什么用雙向鏈表實(shí)現(xiàn)?

android里面lrucache算法為什么用雙向鏈表實(shí)現(xiàn)?LRU是通過雙向鏈表和映射實(shí)現(xiàn)的,在Java中也是通過雙向鏈表實(shí)現(xiàn)的。通過JDK中的LinkedHashMap很容易實(shí)現(xiàn)lrucache。將

android里面lrucache算法為什么用雙向鏈表實(shí)現(xiàn)?

LRU是通過雙向鏈表和映射實(shí)現(xiàn)的,在Java中也是通過雙向鏈表實(shí)現(xiàn)的。通過JDK中的LinkedHashMap很容易實(shí)現(xiàn)lrucache。

將最近訪問的元素放在鏈表的一端,如果容量達(dá)到限制,則從另一端刪除該元素

1。Linkedhashset繼承自hahsset。構(gòu)造方法使用HashSet的三個(gè)參數(shù)調(diào)用該方法。此構(gòu)造方法的底層將初始化LinkedHashMap。因?yàn)長inkedHashMap是有序的,所以linkedhashset也是有序的。為什么我們不能調(diào)用這個(gè)構(gòu)造函數(shù)?它是包訪問級(jí)別,不能在外部調(diào)用。接下來,分析LinkedHashMap是如何實(shí)現(xiàn)的,以理解為什么它是有序的。

2. 先看下面的圖片。(對(duì)于寫在手機(jī)上的問題,你不能把圖片放在文字里,它們都在下面。)。

LinkedHashMap的數(shù)據(jù)結(jié)構(gòu)與HashMap不同。HashMap中的條目有四個(gè)屬性:key、value、hash和next,而LinkedHashMap中的條目添加了before和after屬性。因此,LinkedHashMap在HashMap的基礎(chǔ)上使用雙向鏈表來連接所有節(jié)點(diǎn)。當(dāng)然,它也有一個(gè)頭部節(jié)點(diǎn),所以遍歷可以有序進(jìn)行。具體結(jié)構(gòu)如圖所示。

3. LinkedHashMap主要重寫addentry和createentry方法,在創(chuàng)建節(jié)點(diǎn)時(shí)創(chuàng)建雙向鏈表。

此外,LinkedHashMap還可以實(shí)現(xiàn)LRU算法的緩存。

源代碼基于JDK7查看ha。如果你不懂HashMap,你可以看到我分享的另一篇文章。

希望對(duì)您有所幫助,您可以關(guān)注我,以后會(huì)分享更多的架構(gòu)和java知識(shí)文章。