HashMap的clear方法

我们都知道HashMap的clear()方法会清楚map的映射关系,至于怎么实现的呢?

下面先看一下clear()方法的源码

 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;
        }
    }

可见方法只是把table[]置空了,而存的key-value呢?

原来现代的虚拟机都采用了可达性分析算法来判断一个对象是否存活,当一个对象不能通过任何引用找到它就认为它是不可达的,从而视为可回收的对象,所有存的数据都被gc自动回收了。

猜你喜欢

转载自www.cnblogs.com/lwx521/p/8979543.html