对象与垃圾回收:
java的垃圾回收是java语言的重要功能之一。当程序创建对象、数组等引用实例时,系统都会在堆内存中为其分配一块内存区,对象就保存在这块内存区中,当这块内存区不再被任何引用变量引用时,这块内存就变成了垃圾,等待垃圾回收机制进行回收。
垃圾回收机制具有以下特征:
(1)垃圾回收机制只负责回收堆内存中的垃圾,不回收任何物理资源(例如数据库连接、网络I/O等)
(2)程序无法精确控制垃圾回收机制的运行,垃圾回收会在合适的时候进行。当对象永久性的失去引用后,系统就会在合适的时候回收它的内存。
(3)在垃圾回收机制回收任何对象之前,总会调用它的finalize()方法,该方法可能使该对象重新复活(让一个引用变量重新引用该对象),从而导致垃圾回收机制取消回收。
————————————————————————————————————————————————————————————————————
对象在内存中的状态:
(1)可达状态:一个对象被创建之后,若有一个以上的引用变量引用它,则这个对象在程序中处于可达状态,程序通过引用变量来调用该对象的实例变量和实例方法。
(2)可恢复状态:程序中的某个对象不再有任何引用变量引用它时,他就进入了可恢复状态,系统的垃圾回收机制准备回收该对象所占用的内存。回收之前,系统会调用finalize()方法进行资源资源清理,如果系统在调用finalize()方法时重新让一个引用变量重新引用该对象,则这个对象重新变成可达状态,否则为不可达状态。
(3)当对象与所有引用变量的关联都被切断,且系统已经调用所有的finalize()方法依然没有使该对象达到可达状态,那么该对象将永久性的失去引用。只有当一个对象处于不可达状态时,系统才会真正回收该对象占用的资源。
public class StatusTranfer
{
public static void test()
{
String a =new String("linkinpark");//执行结束后,linkinpark处于可达状态
a=new String("zoulvzhou");//执行后,zoulvzhou处于可执行状态,而linkinpark处于可恢复状态
}
public static void main(String[] args)
{
System.out.println("Hello World!");
}
}
强制垃圾回收:
程序无法精确控制java垃圾回收机制的时机,但依然可以强制系统进行垃圾回收。大部分时候,程序强制系统进行垃圾回收总会有一些效果,强制系统垃圾回收有如下方式。
(1)调用System类的gc()静态方法:System.gc()
(2)调用Runtime对象的gc()实例方法:Running.getRunning().gc()