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

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

Java源碼解析之LinkedHashMap

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

先來(lái)看看存儲(chǔ)元素的結(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); }}

這個(gè)Entry在HashMap中被引用過(guò),主要是為了能讓LinkedHashMap也支持樹(shù)化。在這里則是用來(lái)存儲(chǔ)元素。

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

關(guān)于LinkedHashMap的構(gòu)造函數(shù)我們只關(guān)注一個(gè),其他的都和HashMap類似,只是把a(bǔ)ccessOrder設(shè)置為了false。在上邊的文檔說(shuō)過(guò),initialCapacity并沒(méi)有在HashMap中那般重要,因?yàn)殒湵聿恍枰駭?shù)組那樣必須先聲明足夠的空間。下面這個(gè)構(gòu)造函數(shù)是支持訪問(wèn)順序的。

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

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

1、插入一個(gè)元素

HashMap在插入時(shí),調(diào)用了newNode來(lái)新建一個(gè)節(jié)點(diǎn),或者是通過(guò)replacementNode來(lái)替換值。在樹(shù)化時(shí)也有兩個(gè)對(duì)應(yīng)的方法,分別是newTreeNode和replacementTreeNode。完成之后,還調(diào)用了afterNodeInsertion方法,這個(gè)方法允許我們?cè)诓迦胪瓿珊笞鲂┦虑椋J(rèn)是空實(shí)現(xiàn)。

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

// HashMap中的實(shí)現(xiàn)Node<K, V> newNode(int hash, K key, V value, Node<K, V> next) { return new Node<>(hash, key, value, next);}// LinkedHashMap中的實(shí)現(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中的實(shí)現(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中的實(shí)現(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和此類似

通過(guò)以上對(duì)比,可以發(fā)現(xiàn),LinkedHashMap在新增時(shí),調(diào)用了linkNodeLast,再替換時(shí)調(diào)用了transferLinks。以下是這兩個(gè)方法的實(shí)現(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中說(shuō)過(guò),為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;// 自動(dòng)刪除最老的元素,也就是head元素removeNode(hash(key), key, null, false, true); }}

removeEldestEntry是當(dāng)想要在插入元素時(shí)自動(dòng)刪除最老的元素時(shí)需要復(fù)寫的方法。其默認(rèn)實(shí)現(xiàn)如下:

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

2、查詢

因?yàn)橐С衷L問(wèn)順序,所以獲取元素的方法和HashMap也有所不同。下面我們看下其實(shí)現(xiàn):

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

getNode方法是在HashMap中實(shí)現(xiàn)的,所以這是包裝了一下HashMap的方法,并添加了一個(gè)afterNodeAccess,其實(shí)現(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是前一個(gè)元素,a是后一個(gè)元素LinkedHashMap.Entry<K,V> p = (LinkedHashMap.Entry<K,V>)e, b = p.before, a = p.after;// e要放在末尾,所以沒(méi)有afterp.after = null;// 把e去掉,把b和a接起來(lái)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)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲主播在线| 91免费精品| 麻豆成全视频免费观看在线看| 国产视频一区二| 日本aⅴ免费视频一区二区三区| 日本不卡一二三区黄网| 欧美日韩一区二区三区在线电影| 国产午夜一区| 日本一二区不卡| 亚洲手机视频| 视频一区免费在线观看| 国产一卡不卡| 久久电影tv| 999在线观看精品免费不卡网站| 男人的天堂久久精品| 欧美中文高清| 国产精品99视频| 亚洲成人二区| 中文字幕av亚洲精品一部二部| 国产精品igao视频网网址不卡日韩| 国产盗摄——sm在线视频| 午夜精品免费| 欧美亚洲免费| 午夜精品久久久久久久久久蜜桃| 亚洲精品888| 日本免费一区二区视频| av中文字幕在线观看第一页| 在线亚洲欧美| 欧美激情麻豆| 亚洲激情婷婷| 欧美国产极品| 欧美日韩国产高清| 欧美午夜三级| 激情久久久久久| 久久国产精品色av免费看| 日韩精品看片| 国产精品tv| 99视频在线精品国自产拍免费观看| 777久久精品| 91超碰国产精品| 国产精品网在线观看| 亚洲欧洲一区| 国产一区一一区高清不卡| 在线看片日韩| 91精品蜜臀一区二区三区在线| 91嫩草精品| 午夜精品网站| 精品国产欧美| 日韩avvvv在线播放| 激情久久婷婷| 美女视频一区在线观看| 男女男精品视频网| 精品捆绑调教一区二区三区| 国产剧情在线观看一区| 日韩中文字幕区一区有砖一区| 国产精品伦理久久久久久| 日韩 欧美一区二区三区| 国产专区一区| 成人在线观看免费视频| 日韩国产精品久久久久久亚洲| 欧美 日韩 国产一区二区在线视频| 国产日韩一区二区三区在线| 黄色亚洲大片免费在线观看| 成人在线观看免费视频| 日韩精品视频在线看| 欧美精品自拍| 中文字幕系列一区| 国产一区二区三区日韩精品| 91久久精品无嫩草影院| 老司机精品久久| 午夜影院欧美| 91精品久久久久久久久久不卡| 精品一二三区| 国产精品极品在线观看| 婷婷综合电影| 国产精品日本欧美一区二区三区| 精品三级久久| 久久精品一区二区三区中文字幕| 色8久久久久| 亚洲一区成人| 午夜精品网站| 亚洲调教视频在线观看| 日韩精品dvd| av最新在线| 国产精品久久久久久久久妇女| 麻豆精品久久久| 欧美激情视频一区二区三区免费 | 亚洲人亚洲人色久| 亚洲专区一区| 蜜桃视频在线观看一区| 极品日韩av| 国产精品88久久久久久| 欧美福利一区| 欧美午夜不卡| 国产婷婷精品| 免费精品视频在线| 亚洲精品乱码久久久久久蜜桃麻豆| 日韩一区精品视频| 在线精品福利| 日韩精品高清不卡| 香蕉久久一区| 欧美精品影院| 久久永久免费| 福利欧美精品在线| 五月天av在线| 成人看片网站| 午夜国产欧美理论在线播放| 免播放器亚洲| 日韩av字幕| 国产精品欧美三级在线观看| 国产精品成人国产| 国产不卡人人| 精品日韩毛片| 亚洲欧美在线专区| 国产精品一页| 国产资源在线观看入口av| 美女网站视频一区| 中文精品在线| 欧美在线首页| 国产精品99一区二区三| а√天堂8资源在线| 欧美日韩中文一区二区| 亚洲自啪免费| 国产日韩欧美一区二区三区 | 亚洲少妇一区| 91精品啪在线观看国产爱臀| 麻豆国产精品| 亚洲福利久久| 日韩中文字幕无砖| 久久只有精品| 精品在线播放| 日韩精品乱码av一区二区| 国产精品最新自拍| 婷婷综合六月| 中文字幕免费一区二区| 国产精品v亚洲精品v日韩精品| 亚洲成a人片| 亚洲精品亚洲人成在线观看| 精品久久国产一区| 99re国产精品| 久久久久九九精品影院| 伊人精品一区| 国产三级一区| av不卡免费看| 久久一区国产| 亚洲欧美不卡| 精品99在线| 日韩午夜av| 国产一区二区三区四区五区传媒| 欧美另类专区| 精品一级视频| 三级在线观看一区二区| 国产精品原创| 日韩精品导航| 国产一区日韩欧美| 久久av影视| 中文字幕亚洲精品乱码| 成人在线丰满少妇av| 亚洲人妖在线| 欧美不卡视频| 国产一区二区三区黄网站| 亚洲有吗中文字幕| 综合日韩av| 国产精品黄网站| 午夜在线观看免费一区| 日韩毛片视频| 国产精品99精品一区二区三区∴| 久久国产精品久久久久久电车| 日产精品一区二区| 青青草91久久久久久久久| 午夜久久福利| 97精品国产| 国产精久久久| 日韩激情一二三区| 先锋亚洲精品| 亚洲a一区二区三区| 国产成人免费av一区二区午夜| 一区二区国产在线观看| 米奇777超碰欧美日韩亚洲| 91嫩草亚洲精品| 欧美激情一区| 欧美日韩一区二区高清| 喷白浆一区二区| 午夜av一区| 精品三级久久| 福利精品一区| 精品资源在线| 国产精品4hu.www| 久久狠狠亚洲综合| 日韩国产在线一| 亚洲精品第一| 蜜桃视频第一区免费观看| 久久九九电影| 青青青免费在线视频| 久久99久久人婷婷精品综合| 亚洲精品免费观看| 亚洲一区二区三区无吗| 久久国产精品久久久久久电车| 精品日韩毛片| 亚洲精品国产偷自在线观看|