在jdk8中,HashMap是用了數組和鏈表以及紅黑樹這三種數據結構數組
首先,在hashmap類中,都有一個table數組,咱們在存儲數據時,對這個數據的hash值進行一系列的計算 計算出它在Table中的位置(下標),並將它存放進去
然而,咱們在hashmap是什麼 中提到,不一樣的對象的Hash值可能相同,那麼相同的Hash值會致使不一樣的數據在數組中有相同的存儲位置,咱們雖然創造了一系列的解決辦法,但並不能徹底的避免這種衝突,那麼,當產生衝突時,hashmap是怎樣解決的呢?
當產生衝突時,如data1和data2 ,咱們把data2放在data1後的列表中,這樣就不會由於哈希值的衝突而對數據產生影響。
1.時間複雜度
咱們知道,當某條鏈表的長度大於8時,就會將其轉換爲紅黑樹。遍歷一條鏈表的時間複雜度O(n),當一條鏈表過長時,遍歷這條鏈表可能會花很長時間,而遍歷一顆紅黑樹的時間複雜度爲O(logn),從而減小了插入或查找的時間
2.紅黑樹
簡單總結下紅黑樹是什麼:一種二叉查找樹,但在每一個結點上增長一個存儲位表示結點的顏色,能夠是Red或Black。經過對任何一條從根到葉子的路徑上各個結點着色方式的限制,紅黑樹確保沒有一條路徑會比其餘路徑長出倆倍,於是是接近平衡的。數據結構
也就是說,紅黑樹是一種相對平衡的查找二叉樹,這使他不只便於查找,也便於插入和刪除,這對於既須要插入也須要查找的HashMap是很是有利的spa
下一節:數據哈希值的計算和在table中的存儲位置3d