Skip to content

Commit b3ab980

Browse files
committed
HashMap更新
1 parent d1c4dcd commit b3ab980

File tree

1 file changed

+5
-3
lines changed

1 file changed

+5
-3
lines changed

MD/HashMap.md

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -12,19 +12,21 @@
1212
容量的默认大小是 16,负载因子是 0.75,当 `HashMap``size > 16*0.75` 时就会发生扩容(容量和负载因子都可以自由调整)。
1313

1414
## put 方法
15-
首先会将传入的 Key 做 hash 运算计算出 hashcode,然后根据数组长度取模计算出在数组中的 index 下标。
15+
首先会将传入的 Key 做 `hash` 运算计算出 hashcode,然后根据数组长度取模计算出在数组中的 index 下标。
1616

1717
由于在计算中位运算比取模运算效率高的多,所以 HashMap 规定数组的长度为 `2^n` 。这样用 `2^n - 1` 做位运算与取模效果一致,并且效率还要高出许多。
1818

19-
由于数组的长度有限,所以难免会出现不同的 Key 通过运算得到的 index 相同,这种情况可以利用链表来解决,HashMap 会在 table[index] 处形成环形链表,采用头插法将数据插入到链表中。
19+
由于数组的长度有限,所以难免会出现不同的 Key 通过运算得到的 index 相同,这种情况可以利用链表来解决,HashMap 会在 `table[index]`处形成环形链表,采用头插法将数据插入到链表中。
2020

2121
## get 方法
2222

2323
get 和 put 类似,也是将传入的 Key 计算出 index ,如果该位置上是一个链表就需要遍历整个链表,通过 `key.equals(k)` 来找到对应的元素。
2424

2525
## notice
2626

27-
在并发环境下使用 HashMap 容易出现死循环。当发生扩容时,调用 `resize()` 方法里的 `rehash()` 时,容易出现环形链表。这样当获取一个不存在的 `key` 时,计算出的 `index` 正好是环形链表的下标时就会出现死循环。
27+
在并发环境下使用 `HashMap` 容易出现死循环。
28+
29+
并发场景发生扩容,调用 `resize()` 方法里的 `rehash()` 时,容易出现环形链表。这样当获取一个不存在的 `key` 时,计算出的 `index` 正好是环形链表的下标时就会出现死循环。
2830

2931
![](https://ws2.sinaimg.cn/large/006tNc79gy1fn85u0a0d9j30n20ii0tp.jpg)
3032

0 commit comments

Comments
 (0)