大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 HashMap底層實現原理

HashMap底層實現原理

更新時間:2021-07-23 16:22:14 來源:動力節點 瀏覽917次

1.HashMap的工作原理

HashMap基于hashing原理,我們通過put()和get()方法儲存和獲取對象。當我們將鍵值對傳遞給put()方法時,它調用鍵對象的hashCode()方法來計算hashcode,讓后找到bucket位置來儲存值對象。當獲取對象時,通過鍵對象的equals()方法找到正確的鍵值對,然后返回值對象。HashMap使用鏈表來解決碰撞問題,當發生碰撞了,對象將會儲存在鏈表的下一個節點中。HashMap在每個鏈表節點中儲存鍵值對對象。

當兩個不同的鍵對象的hashcode相同時會發生什么?它們會儲存在同一個bucket位置的鏈表中。鍵對象的equals()方法用來找到鍵值對。

2.HashMap和Hashtable的區別

HashMap和Hashtable都實現了Map接口,但決定用哪一個之前先要弄清楚它們之間的分別。主要的區別有:線程安全性,同步(synchronization),以及速度。

  • HashMap幾乎可以等價于Hashtable,除了HashMap是非synchronized的,并可以接受null(HashMap可以接受為null的鍵值(key)和值(value),而Hashtable則不行)。
  • HashMap是非synchronized,而Hashtable是synchronized,這意味著Hashtable是線程安全的,多個線程可以共享一個Hashtable;而如果沒有正確的同步的話,多個線程是不能共享HashMap的。Java 5提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的擴展性更好。
  • 另一個區別是HashMap的迭代器(Iterator)是fail-fast迭代器,而Hashtable的enumerator迭代器不是fail-fast的。所以當有其它線程改變了HashMap的結構(增加或者移除元素),將會拋出ConcurrentModificationException,但迭代器本身的remove()方法移除元素則不會拋出ConcurrentModificationException異常。但這并不是一個一定發生的行為,要看JVM。這條同樣也是Enumeration和Iterator的區別。
  • 由于Hashtable是線程安全的也是synchronized,所以在單線程環境下它比HashMap要慢。如果你不需要同步,只需要單一線程,那么使用HashMap性能要好過Hashtable。
  • HashMap不能保證隨著時間的推移Map中的元素次序是不變的。

要注意的一些重要術語:

1.sychronized意味著在一次僅有一個線程能夠更改Hashtable。就是說任何線程要更新Hashtable時要首先獲得同步鎖,其它線程要等到同步鎖被釋放之后才能再次獲得同步鎖更新Hashtable。

2.Fail-safe和iterator迭代器相關。如果某個集合對象創建了Iterator或者ListIterator,然后其它的線程試圖“結構上”更改集合對象,將會拋出ConcurrentModificationException異常。但其它線程可以通過set()方法更改集合對象是允許的,因為這并沒有從“結構上”更改集合。但是假如已經從結構上進行了更改,再調用set()方法,將會拋出IllegalArgumentException異常。

3.結構上的更改指的是刪除或者插入一個元素,這樣會影響到map的結構。

我們能否讓HashMap同步?

HashMap可以通過下面的語句進行同步:

Map m=Collections.synchronizeMap(hashMap);

結論

Hashtable和HashMap有幾個主要的不同:線程安全以及速度。僅在你需要完全的線程安全的時候使用Hashtable,而如果你使用Java 5或以上的話,請使用ConcurrentHashMap吧。

ashMap和HashSet的區別是Java面試中最常被問到的問題。如果沒有涉及到Collection框架以及多線程的面試,可以說是不完整。而Collection框架的問題不涉及到HashSet和HashMap,也可以說是不完整。HashMap和HashSet都是collection框架的一部分,它們讓我們能夠使用對象的集合。collection框架有自己的接口和實現,主要分為Set接口,List接口和Queue接口。它們有各自的特點,Set的集合里不允許對象有重復的值,List允許有重復,它對集合中的對象進行索引,Queue的工作原理是FCFS算法(First Come,First Serve)。

首先讓我們來看看什么是HashMap和HashSet,然后再來比較它們之間的分別。

3.HashMap和HashSet的區別

HashMap和HashSet的區別是Java面試中最常被問到的問題。如果沒有涉及到Collection框架以及多線程的面試,可以說是不完整。而Collection框架的問題不涉及到HashSet和HashMap,也可以說是不完整。HashMap和HashSet都是collection框架的一部分,它們讓我們能夠使用對象的集合。collection框架有自己的接口和實現,主要分為Set接口,List接口和Queue接口。它們有各自的特點,Set的集合里不允許對象有重復的值,List允許有重復,它對集合中的對象進行索引,Queue的工作原理是FCFS算法(First Come,First Serve)。

首先讓我們來看看什么是HashMap和HashSet,然后再來比較它們之間的分別。

什么是HashSet

HashSet實現了Set接口,它不允許集合中有重復的值,當我們提到HashSet時,第一件事情就是在將對象存儲在HashSet之前,要先確保對象重寫equals()和hashCode()方法,這樣才能比較對象的值是否相等,以確保set中沒有儲存相等的對象。如果我們沒有重寫這兩個方法,將會使用這個方法的默認實現。

public boolean add(Object o)方法用來在Set中添加元素,當元素值重復時則會立即返回false,如果成功添加的話會返回true。

什么是HashMap

HashMap實現了Map接口,Map接口對鍵值對進行映射。Map中不允許重復的鍵。Map接口有兩個基本的實現,HashMap和TreeMap。TreeMap保存了對象的排列次序,而HashMap則不能。HashMap允許鍵和值為null。HashMap是非synchronized的,但collection框架提供方法能保證HashMap synchronized,這樣多個線程同時訪問HashMap時,能保證只有一個線程更改Map。

public Object put(Object Key,Object value)方法用來將元素添加到map中。

以上就是動力節點小編介紹的"HashMap底層實現原理",希望對大家有幫助,想了解更多可查看HashMap底層實現原理。動力節點在線學習教程,針對沒有任何Java基礎的讀者學習,讓你從入門到精通,主要介紹了一些Java基礎的核心知識,讓同學們更好更方便的學習和了解Java編程,感興趣的同學可以關注一下。

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 奇米网在线观看 | 热久久国产欧美一区二区精品 | 人成午夜欧美大片免费视频 | 天天干天天拍天天射天天添天天爱 | 欧做爰xxxⅹ性欧美图片 | www男女| 日本一级毛片无遮挡 | 国产一级理论免费版 | 一区二区三区高清在线 | 亚洲 欧美 日韩 在线 香蕉 | 国产精品久久在线 | 久久99热这里只有精品国产 | 国产热re99久久6国产精品 | 91精品中文字幕 | 日本特交大片免费观看 | 99视频免费 | 久久久久久一级毛片免费无遮挡 | 日韩黄色片 | 日韩精品欧美亚洲高清有无 | 91久久亚洲国产成人精品性色 | 国产精品你懂的 | 97se在线观看 | 国产一级毛片欧美视频 | 日本波多野结衣字幕久久 | 天天狠狠色综合图片区 | 亚洲精品日本一区二区在线 | 久久久久一 | 全高清特级毛片 | 亚洲线精品久久一区二区三区 | 国产91精品系列在线观看 | 99精品在线看 | 国产一级大片免费看 | 国内精品久久久久丫网址 | 嫩模在线 | 国产成人福利夜色影视 | 欧美色视频超清在线观看 | 日本特黄a级高清免费大片18 | 久久2017| 五月激激激综合网色播免费 | 可以免费观看的毛片 | 中文线码中文高清播放中 |