热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

WeakHashMap的remove方法导致对象回收的测试

定义一个类,在finalize方法中添加logpublicclassTest{intvalue;publicTest(){
    定义一个类,在finalize方法中添加log public class Test{         int value;
        public Test() {             // TODO Auto-generated constructor stub         }
        public Test(int i) {             // TODO Auto-generated constructor stub             value = i;         }
        @Override         protected void finalize() throws Throwable {             // TODO Auto-generated method stub             System.out.println("Test finalize,value=" + value                      + ", this=" + this);
            super.finalize();         }     }
    public void testWMap()     {         //test WeakHashMap         WeakHashMapwmap = new WeakHashMap();         wmap.put(""+1, new Test(1));         wmap.put(""+2, new Test(2));         wmap.put(""+3, new Test(3));         wmap.put(""+4, new Test(4));         wmap.put(""+5, new Test(5));
        System.gc();         System.out.println("wmap.size=" + wmap.size());         wmap.remove("1");
        System.out.println("wmap.size=" + wmap.size());
        for (int i = 6; i < 30; i++) {             wmap.put(""+i, new Test(i));
            System.out.println("== wmap.size=" + wmap.size());         }         //gc do not make the Test object to release         //but remove from the weakmap and than gc can make it release         System.gc();         wmap.remove("2");         for (int i = 0; i < wmap.size(); i++) {
            System.out.println("key=" + wmap.keySet().toArray()[i]);         }         System.out.println("== wmap.size=" + wmap.size()); //        System.gc();
    }
调用testWMap()
wmap.size=5wmap.size=4== wmap.size=5== wmap.size=6== wmap.size=7== wmap.size=8== wmap.size=9== wmap.size=10== wmap.size=11== wmap.size=12== wmap.size=13== wmap.size=14== wmap.size=15== wmap.size=16== wmap.size=17== wmap.size=18== wmap.size=19== wmap.size=20== wmap.size=21== wmap.size=22== wmap.size=23== wmap.size=24== wmap.size=25== wmap.size=26== wmap.size=27== wmap.size=28Test finalize,value=1, this=com.foxx.a.File1$Test@ca0b6key=4key=5key=3== wmap.size=3
可以看出,WeakHashMap中没有被引用的对象可能会被WeakHashMap去掉(remove) 被remove后,再System.gc(),才能够让对象及时的被回收。 WeakHashMap自动remove难以确定何时进行,必要的时候,还是需要调用remove方法

修改为     public void testWMap()    {        //test WeakHashMap        WeakHashMapwmap = new WeakHashMap();        wmap.put(""+1, new Test(1));        wmap.put(""+2, new Test(2));        wmap.put(""+3, new Test(3));        wmap.put(""+4, new Test(4));        wmap.put(""+5, new Test(5));
        System.gc();        System.out.println("wmap.size=" + wmap.size());        wmap.remove("1");
        System.out.println("wmap.size=" + wmap.size());
        for (int i = 6; i < 30; i++) {            wmap.put(""+i, new Test(i));
            System.out.println("== wmap.size=" + wmap.size());        }        //gc do not make the Test object to release        //but remove from the weakmap and than gc can make it release        System.gc();        wmap.remove("2");        for (int i = 0; i < wmap.size(); i++) {
            System.out.println("key=" + wmap.keySet().toArray()[i]);        }        System.out.println("== wmap.size=" + wmap.size());        System.gc();
    }
对象都会被回收 wmap.size=5wmap.size=4== wmap.size=5== wmap.size=6== wmap.size=7== wmap.size=8== wmap.size=9== wmap.size=10== wmap.size=11== wmap.size=12== wmap.size=13== wmap.size=14== wmap.size=15== wmap.size=16== wmap.size=17== wmap.size=18== wmap.size=19== wmap.size=20== wmap.size=21== wmap.size=22== wmap.size=23== wmap.size=24== wmap.size=25== wmap.size=26== wmap.size=27== wmap.size=28Test finalize,value=1, this=com.foxx.a.File1$Test@1a758cbkey=4key=5key=3== wmap.size=3Test finalize,value=13, this=com.foxx.a.File1$Test@69b332Test finalize,value=29, this=com.foxx.a.File1$Test@173a10fnewString=com.UCMobileTest finalize,value=28, this=com.foxx.a.File1$Test@530daaTest finalize,value=27, this=com.foxx.a.File1$Test@a62fc3
Test finalize,value=26, this=com.foxx.a.File1$Test@89ae9e
Test finalize,value=25, this=com.foxx.a.File1$Test@1270b73 Test finalize,value=24, this=com.foxx.a.File1$Test@60aeb0
Test finalize,value=23, this=com.foxx.a.File1$Test@16caf43

Test finalize,value=22, this=com.foxx.a.File1$Test@66848cTest finalize,value=21, this=com.foxx.a.File1$Test@8813f2Test finalize,value=20, this=com.foxx.a.File1$Test@1d58aaeTest finalize,value=19, this=com.foxx.a.File1$Test@83cc67Test finalize,value=18, this=com.foxx.a.File1$Test@e09713Test finalize,value=17, this=com.foxx.a.File1$Test@156ee8eTest finalize,value=16, this=com.foxx.a.File1$Test@47b480Test finalize,value=15, this=com.foxx.a.File1$Test@10d448
Test finalize,value=14, this=com.foxx.a.File1$Test@e0e1c6
Test finalize,value=12, this=com.foxx.a.File1$Test@6ca1cTest finalize,value=11, this=com.foxx.a.File1$Test@1bf216aTest finalize,value=10, this=com.foxx.a.File1$Test@12ac982Test finalize,value=9, this=com.foxx.a.File1$Test@1389e4Test finalize,value=8, this=com.foxx.a.File1$Test@c20e24Test finalize,value=7, this=com.foxx.a.File1$Test@2e7263Test finalize,value=6, this=com.foxx.a.File1$Test@157f0dcTest finalize,value=2, this=com.foxx.a.File1$Test@863399

推荐阅读
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
author-avatar
xhl583337984
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有