WeakHashMap

来源:http://hecc-cqut.iteye.com/blog/984235

在广大的Java界,关于WeakHashMap一直都存在这么个传说:



Java代码
在WeakHashMap 中,当某个键不再正常使用时,自动移除其条目

在WeakHashMap 中,当某个键不再正常使用时,将自动移除其条目 可是WeakHashMap是真的自动移除其条目吗?



今天因为闲来无事,所以想看看WeakHashMap是如何自动实现移除其内部不用的条目从而达到的自动释放内存的目的的。仔细的看了看JVM自带的源代码的实现,在WeakHashMap是主要通过expungeStaleEntries这个函数的来实现的。基本上只要对WeakHashMap的内容进行访问就会调用这个函数,从而达到清除其内部不在为外部引用的条目。但是如果预先生成了WeakHashMap,而在GC以前又不曾访问该WeakHashMap,那不是就不能释放内存了吗?



写个代码测试一把:

Java代码

public static void main(String[] args) throws Exception { 

List<WeakHashMap<byte[][], byte[][]>> maps = new ArrayList<WeakHashMap<byte[][], byte[][]>>(); 

for (int i = 0; i < 1000; i++) { 
WeakHashMap<byte[][], byte[][]> d = new WeakHashMap<byte[][], byte[][]>(); 
d.put(new byte[1000][1000], new byte[1000][1000]); 
maps.add(d); 
System.gc(); 
System.err.println(i); 


} 

} 
由于Java默认内存是64M,所以再不改变内存参数的情况下,该测试跑不了几步循环就内存溢出了。果不其然,WeakHashMap这个时候并没有自动帮我们释放不用的内存。


再加个对会对map进行访问的测试试试:

Java代码  

public static void main(String[] args) throws Exception {   
  
        List<WeakHashMap<byte[][], byte[][]>> maps = new ArrayList<WeakHashMap<byte[][], byte[][]>>();   
  
        for (int i = 0; i < 1000; i++) {   
            WeakHashMap<byte[][], byte[][]> d = new WeakHashMap<byte[][], byte[][]>();   
            d.put(new byte[1000][1000], new byte[1000][1000]);   
            maps.add(d);   
            System.gc();   
            System.err.println(i);   
  
            for (int j = 0; j < i; j++) {   
                System.err.println(j+  " size" + maps.get(j).size());   
            }   
        }   
    }  
这下测试就顺利通过了。



总结来说:WeakHashMap并不是你啥也干他就能自动释放内部不用的对象的,而是在你访问它的内容的时候释放内部不用的对象。这两句话看似区别不大,但是有时候一个小小的区别就会要了命的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值