日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Java源碼解析之LinkedHashMap

瀏覽:31日期:2022-08-11 18:26:49
目錄一、成員變量二、構(gòu)造函數(shù)三、重要方法一、成員變量

先來看看存儲元素的結(jié)構(gòu)吧:

static class Entry<K,V> extends HashMap.Node<K,V> { Entry<K,V> before, after; Entry(int hash, K key, V value, Node<K,V> next) {super(hash, key, value, next); }}

這個Entry在HashMap中被引用過,主要是為了能讓LinkedHashMap也支持樹化。在這里則是用來存儲元素。

// 雙向鏈表的頭,用作AccessOrder時也是最老的元素transient LinkedHashMap.Entry<K,V> head;// 雙向鏈表的尾,用作AccessOrder時也是最新的元素transient LinkedHashMap.Entry<K,V> tail;// true則為訪問順序,false則為插入順序final boolean accessOrder;二、構(gòu)造函數(shù)

關(guān)于LinkedHashMap的構(gòu)造函數(shù)我們只關(guān)注一個,其他的都和HashMap類似,只是把accessOrder設置為了false。在上邊的文檔說過,initialCapacity并沒有在HashMap中那般重要,因為鏈表不需要像數(shù)組那樣必須先聲明足夠的空間。下面這個構(gòu)造函數(shù)是支持訪問順序的。

// 雙向鏈表的頭,用作AccessOrder時也是最老的元素transient LinkedHashMap.Entry<K,V> head;// 雙向鏈表的尾,用作AccessOrder時也是最新的元素transient LinkedHashMap.Entry<K,V> tail;// true則為訪問順序,false則為插入順序final boolean accessOrder;三、重要方法

LinkedHashMap并沒有再實現(xiàn)一整套增刪改查的方法,而是通過復寫HashMap在此過程中定義的幾個方法來實現(xiàn)的。對此不熟悉的可以查看上一篇關(guān)于HashMap分析的文章,或者對照HashMap的源碼來看。

1、插入一個元素

HashMap在插入時,調(diào)用了newNode來新建一個節(jié)點,或者是通過replacementNode來替換值。在樹化時也有兩個對應的方法,分別是newTreeNode和replacementTreeNode。完成之后,還調(diào)用了afterNodeInsertion方法,這個方法允許我們在插入完成后做些事情,默認是空實現(xiàn)。

為了方便分析,我們會對比HashMap中的實現(xiàn)與LinkedHashMap的實現(xiàn),來摸清它是如何做的。

// HashMap中的實現(xiàn)Node<K, V> newNode(int hash, K key, V value, Node<K, V> next) { return new Node<>(hash, key, value, next);}// LinkedHashMap中的實現(xiàn)Node<K,V> newNode(int hash, K key, V value, Node<K,V> e) { LinkedHashMap.Entry<K,V> p =new LinkedHashMap.Entry<K,V>(hash, key, value, e); linkNodeLast(p); return p;}// HashMap中的實現(xiàn)Node<K, V> replacementNode(Node<K, V> p, Node<K, V> next) { return new Node<>(p.hash, p.key, p.value, next);}// LinkedHashMap中的實現(xiàn)Node<K,V> replacementNode(Node<K,V> p, Node<K,V> next) { LinkedHashMap.Entry<K,V> q = (LinkedHashMap.Entry<K,V>)p; LinkedHashMap.Entry<K,V> t =new LinkedHashMap.Entry<K,V>(q.hash, q.key, q.value, next); transferLinks(q, t); return t;}// newTreeNode和replacementTreeNode和此類似

通過以上對比,可以發(fā)現(xiàn),LinkedHashMap在新增時,調(diào)用了linkNodeLast,再替換時調(diào)用了transferLinks。以下是這兩個方法的實現(xiàn)。

// 就是將元素掛在鏈尾private void linkNodeLast(LinkedHashMap.Entry<K,V> p) { LinkedHashMap.Entry<K,V> last = tail; tail = p; if (last == null)head = p; else {p.before = last;last.after = p; }}// 用dst替換srcprivate void transferLinks(LinkedHashMap.Entry<K,V> src, LinkedHashMap.Entry<K,V> dst) { LinkedHashMap.Entry<K,V> b = dst.before = src.before; LinkedHashMap.Entry<K,V> a = dst.after = src.after; if (b == null)head = dst; elseb.after = dst; if (a == null)tail = dst; elsea.before = dst;}

最后我們看下afterNodeInsertion做了哪些事情吧:

// evict在HashMap中說過,為false表示是創(chuàng)建階段void afterNodeInsertion(boolean evict) { // possibly remove eldest LinkedHashMap.Entry<K,V> first; // 不是創(chuàng)建階段 if (evict && (first = head) != null && removeEldestEntry(first)) {K key = first.key;// 自動刪除最老的元素,也就是head元素removeNode(hash(key), key, null, false, true); }}

removeEldestEntry是當想要在插入元素時自動刪除最老的元素時需要復寫的方法。其默認實現(xiàn)如下:

protected boolean removeEldestEntry(Map.Entry<K,V> eldest) { return false;}

2、查詢

因為要支持訪問順序,所以獲取元素的方法和HashMap也有所不同。下面我們看下其實現(xiàn):

public V get(Object key) { Node<K,V> e; if ((e = getNode(hash(key), key)) == null)return null; if (accessOrder)// 數(shù)據(jù)被訪問,需要將其移動到末尾afterNodeAccess(e); return e.value;}

getNode方法是在HashMap中實現(xiàn)的,所以這是包裝了一下HashMap的方法,并添加了一個afterNodeAccess,其實現(xiàn)如下:

void afterNodeAccess(Node<K,V> e) { // move node to last LinkedHashMap.Entry<K,V> last; // e元素不在末尾 if (accessOrder && (last = tail) != e) {// p是e,b是前一個元素,a是后一個元素LinkedHashMap.Entry<K,V> p = (LinkedHashMap.Entry<K,V>)e, b = p.before, a = p.after;// e要放在末尾,所以沒有afterp.after = null;// 把e去掉,把b和a接起來if (b == null) head = a;else b.after = a;if (a != null) a.before = b;else last = b;//把e接在末尾if (last == null) head = p;else { p.before = last; last.after = p;}tail = p;++modCount; }}

到此這篇關(guān)于Java源碼解析之LinkedHashMap的文章就介紹到這了,更多相關(guān)Java LinkedHashMap內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Java
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲日产国产精品| 久久a爱视频| 日韩伦理福利| 理论片午夜视频在线观看| 国产福利一区二区精品秒拍| 91精品国产自产在线丝袜啪| 一区二区国产精品| 日韩欧美中文字幕一区二区三区 | 国产精品一区二区三区www| 日韩精品福利一区二区三区| 无码日韩精品一区二区免费| 日韩av黄色在线| 国产精品伦一区二区| 国产一区二区三区日韩精品| 成人一二三区| 婷婷激情综合| 一区二区三区国产盗摄| 日韩福利在线观看| 国产精品久久久久9999高清| 久久精品资源| 国产精品久久久久久久久久10秀| 日本激情一区| 欧美综合另类| 性欧美长视频| 欧美一区在线观看视频| 欧美交a欧美精品喷水| 另类欧美日韩国产在线| 国产中文欧美日韩在线| 啪啪国产精品| 热久久国产精品| 国产麻豆一区二区三区精品视频| 美女视频网站久久| 欧美日韩一二三四| 亚洲精品护士| 精品不卡一区| 欧美精品一区二区三区精品| 免费黄网站欧美| 久久不见久久见中文字幕免费| 国产色播av在线| 久久国产精品99国产| 国产日产高清欧美一区二区三区| 美女毛片一区二区三区四区最新中文字幕亚洲 | 欧美日韩国产高清电影| 日韩精品一级二级| 久久伊人久久| 黑丝一区二区三区| 亚洲免费专区| 亚洲午夜天堂| 中文字幕av一区二区三区四区| 国产精品羞羞答答在线观看| 欧美日韩国产观看视频| 日韩一区精品视频| 97精品中文字幕| 伊人久久大香伊蕉在人线观看热v| 麻豆精品新av中文字幕| 婷婷丁香综合| 精品亚洲a∨一区二区三区18| 欧美二区视频| 国产毛片精品久久| 欧美特黄一区| 国产精品.xx视频.xxtv| 久久国产影院| 日本va欧美va瓶| 视频福利一区| 国产日韩高清一区二区三区在线| 99久久夜色精品国产亚洲1000部| 久久精品99久久久| 亚洲国产一区二区在线观看| 欧美国产中文高清| 蜜臀av国产精品久久久久| 国产a久久精品一区二区三区| 日韩中文字幕av电影| 日韩国产综合| 国产精品麻豆成人av电影艾秋 | 午夜亚洲福利| 欧美日韩视频网站| 国产美女精品视频免费播放软件| 红桃视频国产一区| 国产精品不卡| 欧美精品观看| 亚洲伊人影院| 1000部精品久久久久久久久| 国产极品一区| 亚洲另类黄色| 欧美不卡高清| 91亚洲人成网污www| 青青在线精品| 爽爽淫人综合网网站| 黄色aa久久| 国产乱码精品一区二区三区亚洲人| 午夜一级久久| 国产精品7m凸凹视频分类| 日韩电影免费网址| 国产第一亚洲| 久久99影视| 久久国产麻豆精品| 午夜电影一区| 视频在线观看一区| 99视频+国产日韩欧美| 91精品久久久久久久久久不卡| 久久精品人人| 国产精品主播在线观看| 亚洲久久视频| 日韩中文欧美在线| 亚洲一区区二区| 午夜久久福利| 欧美日韩国产免费观看| 999国产精品999久久久久久| 日本不卡免费高清视频在线| 国产在线观看91一区二区三区 | 综合在线一区| 免费在线观看视频一区| 欧美日韩国产探花| 国产高清一区| 亚洲精品99| 五月精品视频| 欧美日韩在线播放视频| 在线精品亚洲欧美日韩国产| 精品国产乱码久久久| 另类小说一区二区三区| 国产精品激情| 国产精品香蕉| 欧美精品91| 高清日韩中文字幕| 中文字幕在线视频网站| 日韩精品专区| 精品欧美激情在线观看| 夜夜嗨一区二区| 免费成人在线视频观看| 亚洲精品一二三**| 日韩在线网址| 国产亚洲第一伦理第一区| 国产亚洲欧美日韩在线观看一区二区 | 婷婷综合国产| 日韩中文字幕| 国产精品亚洲片在线播放| 麻豆精品蜜桃视频网站| 国产精品国产一区| 91精品一区二区三区综合在线爱| 99久久夜色精品国产亚洲1000部 | 日韩在线不卡| 亚洲国产专区校园欧美| 伊人精品视频| 综合国产视频| 国产欧美日韩一级| 国产精品极品在线观看| 日韩成人精品一区| 999国产精品| 亚洲精品字幕| 久久99影视| 日本免费久久| 亚洲欧美日韩在线观看a三区| 日韩免费精品| 国产精品.xx视频.xxtv| av亚洲一区二区三区| aa亚洲婷婷| 国产精品欧美在线观看| 日韩伦理在线一区| 久久不射网站| 国产精品xxxav免费视频| 国产精品国产一区| 亚洲精品va| 日本vs亚洲vs韩国一区三区二区| 欧美激情五月| 亚洲福利精品| 日本成人手机在线| 色综合五月天| 乱人伦精品视频在线观看| 日韩av在线免费观看不卡| 国产一区二区三区不卡视频网站| 婷婷成人基地| 国产精品一区免费在线| 久久人人97超碰国产公开结果| 蜜桃一区二区三区在线观看| 国产精品一区二区精品视频观看 | 99国产精品免费视频观看| 爽好久久久欧美精品| 美女在线视频一区| 不卡av一区二区| 国产亚洲欧美日韩精品一区二区三区 | 日韩精品导航| 欧洲一区二区三区精品| 蜜桃久久久久久| 精品一区二区三区的国产在线观看| 合欧美一区二区三区| 久久99精品久久久久久园产越南| 亚洲香蕉网站| 国产精品一国产精品k频道56| 久久久人人人| 欧美日韩精品一区二区三区视频 | 女人av一区| 国产精品久久久亚洲一区| 激情综合网址| 欧美精品导航| 亚洲欧美成人综合| 国产一区二区三区四区二区| 蜜臀久久久久久久| 日韩在线综合| 日韩毛片网站| 五月婷婷六月综合|