JAVA:对象的清除回收

对象的清除,也就是垃圾的回收。

和对象的清除相关的方法有两个:finalize()gc().

(1),这个finalize()方法是object类的一个方法,任何一个类都从object继承了这个方法。

注意finalize()方法是在对象被当做垃圾从内存中释放前调用,而不是在对象变成垃圾前调用。但这个垃圾回收器的启用不由程序员控制,并不会一产生垃圾就会被唤起,甚至有可能到程序终止,它都没启动的机会。

因此,Java提供了一个System.gc()方法,来强制启动垃圾回收器来回收,也就是打个电话让finalize()来清除垃圾。

下面举个例子:

TCabinetCard cabinetCard=t.gettCabinetCardService().get(strs[1].toString());
			if (null==cabinetCard) {
				session.write("Card Error");
			}else if(cabinetCard.getCardType().equals("0")){
				session.write(JsonMapper.toJsonString(cabinetCard));
			}else if(cabinetCard.getCardType().equals("2")){
				//TCabinetCard cabinetCard = new CabinetCard;
				System.gc();
				cabinetCard.setCardType("2");//重新赋值
				List list=t.gettCabinetCardService().findList(cabinetCard);
				session.write(JsonMapper.toJsonString(list));
			}else if(cabinetCard.getCardType().equals("1")) {
				session.write("Super User");
			}

不用在new对象

第三个判断是根据对象中的类型来判断,前面取过整个对象的属性,回收当前对象在进行赋值

细节做起

时间: 2024-10-29 19:06:17

JAVA:对象的清除回收的相关文章

[Java] 监控java对象回收的原理与实现

监控Java对象回收的原理与实现 一.监控Java对象回收的目的 监控Java对象是否回收的目的是:为了实现内存泄露报警. 内存泄露是指程序中对象生命周期(点击查看详情)已经进入不可见阶段,但由于编码错误或系统原因,仍然存在着GC roots持有或间接持有该对象的引用,导致该对象的生命周期无法继续向下流转,也就无法释放的现象.简单的来说即是:已实例化的对象长期被持有且无法释放或不能按照对象正常的生命周期进行释放.(点击这里查看<[Android]内存泄露排查实战手记>) 实现内存泄露报警,可以

Java对象&quot;后事处理&quot;那点事儿——垃圾回收(一)

1.Dead Or Alive 我们都知道对象死亡的时候需要进行垃圾回收来回收这些对象从而释放空间,那么什么样的对象算是死亡呢,有哪些方法可以找出内存中的死亡对象呢?一般来说,我们可以这样认为:如果内存中不存在对当前对象的引用,则此对象一定是死亡状态:但是死亡状态的对象并不一定没有其他对象进行引用(可能存在死亡对象循环引用的情况).这里需要说明一下,死亡的对象并不一定会被回收释放占用的空间,这种情况就是常称的"内存泄漏".判定对象存活的算法一般是以下两种. 1.1 引用计数法 引用计数

Java对象回收流程

一.可回收对象判断 引用计数器算法:为对象放置一个引用计数器,当对象被引用时则计数器加一,如果一个对象的计数器标识为零的时候,则表明该对象可被回收.这种方法比较简单,但无法解决对象之间互相引用的情况. GC Roots算法:该方法可以解决上面算法中的对象互相引用无法判断可回收状态的问题.顾名思义,GC Root指的是程序使用对象,总会有一个"入口",这里可以是栈里的本地变量引用,也可以是方法区中的类静态属性引用.常量引用.JNI的Java引用.当一个对象,如果所有的GC Root沿着对

java语言及其垃圾回收机制简单概述

 一.java 语言概述 Java 语言是一门纯粹的面向对象编程语言,它吸收了c++语言的各种优点.又摈弃了c++里难以理解的多继承,指针等概念因此Java语言具有功能强大和简单易用两个特征. Java语言的几个重要概念如下: J2ME:主要用于控制移动设备和信息家电等有限存储设备 J2SE:整个java技术的核心和基础, J2EE:java技术中应用最最广泛的部分,它提供了企业应用开发相关的完整的解决方案. API: 核心类库 JRE:运行Java程序所必须的环境的集合,包含JVM标准实现及J

Java:对象的强、软、弱和虚引用(转)

1.对象的强.软.弱和虚引用 在JDK 1.2以前的版本中,若一个对象不被任何变量引用,那么程序就无法再使用这个对象.也就是说,只有对象处于可触及(reachable)状态,程序才能使用它.从JDK 1.2版本开始,把对象的引用分为4种级别,从而使程序能更加灵活地控制对象的生命周期.这4种级别由高到低依次为:强引用.软引用.弱引用和虚引用.图1为对象应用类层次. 图1 ⑴强引用(StrongReference) 强引用是使用最普遍的引用.如果一个对象具有强引用,那垃圾回收器绝不会回收它.当内存空

Java对象的生命周期与作用域的讨论(转)

导读: Java对象的生命周期大致包括三个阶段:对象的创建,对象的使用,对象的清除.因此,对象的生命周期长度可用如下的表达式表示:T = T1 + T2 +T3.其中T1表示对象的创建时间,T2表示对象的使用时间,而T3则表示其清除时间.由此,我们可以看出,只有T2是真正有效的时间,而T1.T3则是对象本身的开销.下面再看看T1.T3在对象的整个生命周期中所占的比例. 我们知道,Java对象是通过构造函数来创建的,在这一过程中,该构造函数链中的所有构造函数也都会被自动调用.另外,默认情况下,调用

Java深入 - Java 内存分配和回收机制-转

Java的GC机制是自动进行的,和c语言有些区别需要程序员自己保证内存的使用和回收. Java的内存分配和回收也主要在Java的堆上进行的,Java的堆中存储了大量的对象实例,所以Java的堆也叫GC堆. Java在垃圾收集的过程中,主要用到了分代收集算法,我会先讲一下常用垃圾收集算法. 常用垃圾收集算法 1. 标记-清除算法 这种垃圾收集算法思路非常简单,主要是首先标记出所有需要回收的对象,然后回收所有需要回收的对象. 但是有一个明显的缺点,采用这种算法之后会发现内存块回收之后就不连续了,这就

java内存报警 垃圾回收

jdk6和7服务器端(-server) 默认的新生的垃圾回收器为:PS Scavenge,老年代默认的垃圾回收器为:PS MarkSweep 目前项目使用jdk7,tomcat7,经常出现内存堆使用量200s持续超过堆总内存80%,触发报警. 由于项目最近的更新为jdk和tomcat升级,从6升级到7,而之前使用tomcat6时并未报警,据查是由于tomcat的一个监听器行为模式变更造成的 <Listener className="org.apache.catalina.core.JreM

二、Java如何分配和回收内存?Java垃圾收集器如何工作?

线程私有的内存区域随用户线程的结束而回收,内存分配编译期已确定,内存分配和回收具有确定性.共享线程随虚拟机的启动.结束而建立和销毁,在运行期进行动态分配.垃圾收集器主要对共享内存区域(堆和方法区)进行垃圾收集回收. Java如何实现内存动态分配和内存垃圾的回收? 1.哪些内存需要回收(垃圾收集器内存回收的对象)?已经"死亡"的对象,那如何判定对象已经"死亡"了? Java堆回收的内存:已经"死亡"的对象 方法区回收的内存:废弃的常量和无用的类 2