了解Hash衝突首先了解Hash演算法與Hash表
如圖,在Hash表索引1的位置存了key=name,再向它添加key=hobby的時候,假設計算得到的索引也是1,那麼這個時候發生哈希衝突,而開放開放定址法就是按照順序向前找到一個空閒的位置,來儲存這個衝突的key鍊式尋址法,這是一種常見的方法,簡單理解就是把存在Hash衝突的key,以單向鍊錶來進行存儲,例如HashMap #如圖存在衝突的key直接以單向鍊錶的方式去進行存儲
再Hash法,就是透過某個Hash函數計算的key,存在衝突的時候,再用另外一個Hash函數對這個可以進行Hash,一直運算,直到不再產生衝突為止,這種方式會增加計算的一個時間,性能上呢會有一些影響建立公共移除區,就是把Hash表分為基本表和益處表兩個部分,凡是存在衝突的元素,一律放到益處表中4.HashMap在JDK1.8版本的最佳化HashMap在JDK1.8版本中是透過鍊式尋址法以及紅黑樹來解決Hash衝突的問題,其中紅黑樹是為了優化Hash表的鍊錶過長導致時間複雜度增加的問題,當鍊錶長度大於等於8並且Hash表的容量大於64的時候,再向鍊錶添加元素,就會觸發鍊錶向紅黑樹的一個轉化
以上是Java中HashMap如何解決哈希衝突問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!