JAVA基础(十)-----对象与垃圾回收
java的垃圾回收是java语言的重要功能之一。当程序创建对象、数组等引用实例时,系统都会在堆内存中为其分配一块内存区,对象就保存在这块内存区中,当这块内存区不再被任何引用变量引用时,这块内存就变成了垃圾,等待垃圾回收机制进行回收。
垃圾回收机制具有以下特征:
(1)垃圾回收机制只负责回收堆内存中的垃圾,不回收任何物理资源(例如数据库连接、网络I/O等)
(2)程序无法精确控制垃圾回收机制的运行,垃圾回收会在合适的时候进行。当对象永久性的失去引用后,系统就会在合适的时候回收它的内存。
(3)在垃圾回收机制回收任何对象之前,总会调用它的finalize()方法,该方法可能使该对象重新复活(让一个引用变量重新引用该对象),从而导致垃圾回收机制取消回收。
一、对象在内存中的状态
(1)可达状态:一个对象被创建之后,若有一个以上的引用变量引用它,则这个对象在程序中处于可达状态,程序通过引用变量来调用该对象的实例变量和实例方法。
(2)可恢复状态:程序中的某个对象不再有任何引用变量引用它时,他就进入了可恢复状态,系统的垃圾回收机制准备回收该对象所占用的内存。回收之前,系统会调用finalize()方法进行资源资源清理,如果系统在调用finalize()方法时重新让一个引用变量重新引用该对象,则这个对象重新变成可达状态,否则为不可达状态。
(3)不可达状态:当对象与所有引用变量的关联都被切断,且系统已经调用所有的finalize()方法依然没有使该对象达到可达状态,那么该对象将永久性的失去引用。只有当一个对象处于不可达状态时,系统才会真正回收该对象占用的资源。
二、强制垃圾回收
程序无法精确控制java垃圾回收机制的时机,但依然可以强制系统进行垃圾回收。大部分时候,程序强制系统进行垃圾回收总会有一些效果,强制系统垃圾回收有如下方式。
(1)调用System类的gc()静态方法:System.gc()
(2)调用Runtime对象的gc()实例方法:Running.getRunning().gc()
三、finalize方法
finalize()方法有如下四个特点:
1、永远不要主动调用某个对象的finalize()方法,该方法交给垃圾回收机制调用。
2、该方法何时被调用,是否被调用具有不确定性,不要把finalize方法当成一定会被执行的方法。
3、当JVM执行可恢复对象的finalize()方法时,可能使该对象或系统中其他对象重新变为可达状态。
4、当JVM执行finalize()方法出现异常时,垃圾回收机制不会报告异常,程序继续执行。
四、对象的软、弱、虚引用
1.强引用(StrongReference)
程序创建一个对象,并把这个对象赋给一个引用变量,程序通过该引用变量来操作实际的对象。
2.软引用(SoftReference)
通过SoftReference类来实现。对于只有软引用的对象而言,当系统内存空间足够时,它不会被系统回收;当系统内存空间不足时,系统可能会回收它。软引用通常用于对内存敏感的程序中。
3.弱引用(WeakReference)
通过WeakReference类来实现。与软引用相像,但引用级别比软引用更低。当系统垃圾回收机制运行时,不管系统内存是否足够,总会回收该对象所占用的内存。
4.虚引用(PhantomReference)
通过PhantomReference类来实现。如果一个对象只有一个虚引用时,它和没有引用的效果大致相同。主要用于跟踪对象被垃圾回收的状态,不能单独使用,必须和引用队列(ReferenceQueue)联合使用
浙公网安备 33010602011771号