电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Java源碼解析之LinkedHashMap

瀏覽:3日期:2022-08-11 18:26:49
目錄一、成員變量二、構造函數三、重要方法一、成員變量

先來看看存儲元素的結構吧:

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;二、構造函數

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

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

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

1、插入一個元素

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

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

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

通過以上對比,可以發現,LinkedHashMap在新增時,調用了linkNodeLast,再替換時調用了transferLinks。以下是這兩個方法的實現。

// 就是將元素掛在鏈尾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表示是創建階段void afterNodeInsertion(boolean evict) { // possibly remove eldest LinkedHashMap.Entry<K,V> first; // 不是創建階段 if (evict && (first = head) != null && removeEldestEntry(first)) {K key = first.key;// 自動刪除最老的元素,也就是head元素removeNode(hash(key), key, null, false, true); }}

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

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

2、查詢

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

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

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

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; }}

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

標簽: Java
相關文章:
主站蜘蛛池模板: 北京森语科技有限公司-模型制作专家-展览展示-沙盘模型设计制作-多媒体模型软硬件开发-三维地理信息交互沙盘 | 蜜蜂职场文库_职场求职面试实用的范文资料大全 | 3dmax渲染-效果图渲染-影视动画渲染-北京快渲科技有限公司 | 北京宣传片拍摄_产品宣传片拍摄_宣传片制作公司-现像传媒 | 广州二手电缆线回收,旧电缆回收,广州铜线回收-广东益福电缆线回收公司 | 地埋式垃圾站厂家【佳星环保】小区压缩垃圾中转站转运站 | 高空重型升降平台_高空液压举升平台_高空作业平台_移动式升降机-河南华鹰机械设备有限公司 | 无线讲解器-导游讲解器-自助讲解器-分区讲解系统 品牌生产厂家[鹰米讲解-合肥市徽马信息科技有限公司] | 浙江栓钉_焊钉_剪力钉厂家批发_杭州八建五金制造有限公司 | 博莱特空压机|博莱特-阿特拉斯独资空压机品牌核心代理商 | 政府回应:200块在义乌小巷能买到爱情吗?——揭秘打工族省钱约会的生存智慧 | 耐酸碱泵-自吸耐酸碱泵型号「品牌厂家」立式耐酸碱泵价格-昆山国宝过滤机有限公司首页 | 威海防火彩钢板,威海岩棉复合板,威海彩钢瓦-文登区九龙岩棉复合板厂 | 山东商品混凝土搅拌楼-环保型搅拌站-拌合站-分体仓-搅拌机厂家-天宇 | 滚筒线,链板线,总装线,流水线-上海体能机电有限公司 | 礼堂椅厂家|佛山市艺典家具有限公司 | 食品无尘净化车间,食品罐装净化车间,净化车间配套风淋室-青岛旭恒洁净技术有限公司 | 潍坊大集网-潍坊信息港-潍坊信息网| 手术室净化装修-手术室净化工程公司-华锐手术室净化厂家 | 超声波焊接机,振动摩擦焊接机,激光塑料焊接机,超声波焊接模具工装-德召尼克(常州)焊接科技有限公司 | 手机存放柜,超市储物柜,电子储物柜,自动寄存柜,行李寄存柜,自动存包柜,条码存包柜-上海天琪实业有限公司 | 切铝机-数控切割机-型材切割机-铝型材切割机-【昆山邓氏精密机械有限公司】 | 耐酸碱泵-自吸耐酸碱泵型号「品牌厂家」立式耐酸碱泵价格-昆山国宝过滤机有限公司首页 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 无线讲解器-导游讲解器-自助讲解器-分区讲解系统 品牌生产厂家[鹰米讲解-合肥市徽马信息科技有限公司] | 应急灯_消防应急灯_应急照明灯_应急灯厂家-大成智慧官网 | 半自动预灌装机,卡式瓶灌装机,注射器灌装机,给药器灌装机,大输液灌装机,西林瓶灌装机-长沙一星制药机械有限公司 | 食品质构分析仪-氧化诱导分析仪-瞬态法导热系数仪|热冰百科 | 贵州水玻璃_-贵阳花溪闽兴水玻璃厂| 粘度计,数显粘度计,指针旋转粘度计 | [官网]叛逆孩子管教_戒网瘾学校_全封闭问题青少年素质教育_新起点青少年特训学校 | 昆明挖掘机修理厂_挖掘机翻新再制造-昆明聚力工程机械维修有限公司 | 存包柜厂家_电子存包柜_超市存包柜_超市电子存包柜_自动存包柜-洛阳中星 | 贵阳用友软件,贵州财务软件,贵阳ERP软件_贵州优智信息技术有限公司 | 胶辊硫化罐_胶鞋硫化罐_硫化罐厂家-山东鑫泰鑫智能装备有限公司 意大利Frascold/富士豪压缩机_富士豪半封闭压缩机_富士豪活塞压缩机_富士豪螺杆压缩机 | 天长市晶耀仪表有限公司| 真空包装机-诸城市坤泰食品机械有限公司 | 拖鞋定制厂家-品牌拖鞋代加工厂-振扬实业中国高端拖鞋大型制造商 | 仪器仪表网 - 永久免费的b2b电子商务平台 | 数显恒温培养摇床-卧式/台式恒温培养摇床|朗越仪器 | 加中寰球移民官网-美国移民公司,移民机构,移民中介,移民咨询,投资移民 |