Java hashmap 中clear方法疑惑
气自华 2016-10-18 03:58:03 public void clear() {
Node<K,V>[] tab;
modCount++;
if ((tab = table) != null && size > 0) {
size = 0;
for (int i = 0; i < tab.length; ++i)
tab[i] = null;//此循环只在遍历数组,置空表头,链表其他元素并未置空
}
}
此方法为hashMap源码中清空map元素的方法,感觉只是置空(回收)了table数组的元素,及链表的表头元素,如果表头被置为null,无法进入该链表,链表就会被JVM中GC给回收掉?