摘要:也就是說,紅黑樹是一種相對平衡的查找二叉樹,這使他不僅便于查找,也便于插入和刪除,這對于既需要插入也需要查找的是非常有利的下一節數據哈希值的計算和在中的存儲位置
在jdk8中,HashMap是用了數組和鏈表以及紅黑樹這三種數據結構
首先,在hashmap類中,都有一個table數組,我們在存儲數據時,對這個數據的hash值進行一系列的計算 計算出它在Table中的位置(下標),并將它存放進去
然而,我們在hashmap是什么 中提到,不同的對象的Hash值可能相同,那么相同的Hash值會導致不同的數據在數組中有相同的存儲位置,我們雖然創造了一系列的解決辦法,但并不能完全的避免這種沖突,那么,當產生沖突時,hashmap是怎樣解決的呢?
當產生沖突時,如data1和data2 ,我們把data2放在data1后的列表中,這樣就不會因為哈希值的沖突而對數據產生影響。
1.時間復雜度
我們知道,當某條鏈表的長度大于8時,就會將其轉換為紅黑樹。遍歷一條鏈表的時間復雜度O(n),當一條鏈表過長時,遍歷這條鏈表可能會花很長時間,而遍歷一顆紅黑樹的時間復雜度為O(logn),從而減少了插入或查找的時間
2.紅黑樹
簡單總結下紅黑樹是什么:一種二叉查找樹,但在每個結點上增加一個存儲位表示結點的顏色,可以是Red或Black。通過對任何一條從根到葉子的路徑上各個結點著色方式的限制,紅黑樹確保沒有一條路徑會比其他路徑長出倆倍,因而是接近平衡的。
也就是說,紅黑樹是一種相對平衡的查找二叉樹,這使他不僅便于查找,也便于插入和刪除,這對于既需要插入也需要查找的HashMap是非常有利的
下一節:數據哈希值的計算和在table中的存儲位置
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/69986.html
摘要:當一個值中要存儲到的時候會根據的值來計算出他的,通過哈希來確認到數組的位置,如果發生哈希碰撞就以鏈表的形式存儲在源碼分析中解釋過,但是這樣如果鏈表過長來的話,會把這個鏈表轉換成紅黑樹來存儲。 正文開始 注:JDK版本為1.8 HashMap1.8和1.8之前的源碼差別很大 目錄 簡介 數據結構 類結構 屬性 構造方法 增加 刪除 修改 總結 1.HashMap簡介 H...
摘要:源碼解析的數據存儲結構中的都是存在數組中的數據節點的數據結構是一個單向的鏈表,,實現了的接口,即實現了,,等這些函數,這些都是基本的讀取修改值的函數。的作用是判斷是否包含的作用是判斷是否包含值為的元素 HashMap源碼解析 hashmap的數結構 (1)在Java中,數據結構分為兩種,一種是數組,另一個是模型指針即引用,所有的數據結構都可以用這兩種基本結構所構造,HashMap就是一...
摘要:則使用了拉鏈式的散列算法,并在中引入了紅黑樹優化過長的鏈表。如果大家對紅黑樹感興趣,可以閱讀我的另一篇文章紅黑樹詳細分析。構造方法構造方法分析的構造方法不多,只有四個。 1.概述 本篇文章我們來聊聊大家日常開發中常用的一個集合類 - HashMap。HashMap 最早出現在 JDK 1.2中,底層基于散列算法實現。HashMap 允許 null 鍵和 null 值,在計算哈鍵的哈希值...
摘要:根據的重新計算值。如果這兩個的通過比較返回,新添加的將覆蓋集合中原有的,但不會覆蓋。如果這兩個的通過比較返回,新添加的將與集合中原有形成鏈,而且新添加的位于鏈的頭部具體說明繼續看方法的說明。 關于hashCode hashCode的存在主要是用于查找的快捷性,如Hashtable,HashMap等,hashCode是用來在散列存儲結構中確定對象的存儲地址的. 1.hashcode是用來...
摘要:加載因子是哈希表在其容量自動增加之前可以達到多滿的一種尺度。當哈希表中的條目數超出了加載因子與當前容量的乘積時,則要對該哈希表進行操作即重建內部數據結構,從而哈希表將具有大約兩倍的桶數。 showImg(https://upload-images.jianshu.io/upload_images/4565148-98b22ba5ae7d9723.jpg?imageMogr2/auto-...
閱讀 3513·2023-04-25 15:52
閱讀 585·2021-11-19 09:40
閱讀 2598·2021-09-26 09:47
閱讀 1031·2021-09-22 15:17
閱讀 3555·2021-08-13 13:25
閱讀 2223·2019-08-30 15:56
閱讀 3468·2019-08-30 13:56
閱讀 2104·2019-08-30 11:27