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给回收掉?
...全文
574 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
气自华 2016-11-17
  • 打赏
  • 举报
回复
同意2楼的观点
sky_08_06_02 2016-10-19
  • 打赏
  • 举报
回复
rendason 2016-10-18
  • 打赏
  • 举报
回复
现代的虚拟机都采用了可达性分析算法来判断一个对象是否存活,当一个对象不能通过任何引用找到它就认为它是不可达的,从而视为可回收的对象
霜之哀伤 2016-10-18
  • 打赏
  • 举报
回复
头值为空了, 身体和尾巴就变成孤岛,没有任何引用可以拿到那些对象了。 回收的时候这些也就会回收了

62,628

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧