疯狂java讲义阅读笔记—第六章 面向对象(下)(3)

垃圾回收机制具有如下特点:

垃圾回收机制只负责回收堆内存中的对象,不会回收任何物理资源。

程序无法精确控制垃圾回收机制的运行,垃圾回收会在合适的时候进行。当对象永久性的失去引用后,系统就会在合适的时候回收它所占的内存。程序只能控制一个对象合适不再被任何引用变量引用,据不能控制它何时被回收。

在垃圾回收机制回收任何兑现之前,总会先调用它的finalize()方法,该方法可能使该对象重新复活(让一个引用变量重新引用该对象),从而导致垃圾回收机制取消回收。

对象在内存中的状态:

可达状态:当一个对象被创建后,若有一个以上的引用变量引用它,则这个对象在程序中处于可达状态,程序可通过引用变量来调用该对象的实例变量和方法。

可恢复状态:如果程序中某个对象不再有任何引用变量引用它,它就进入了可恢复状态。在这种状态下,系统的垃圾回收机制准备回收该对象所占用的内存,在回收该对象之前,系统会调用所有可恢复状态对象的finaliz()方法进行资源清理。如果系统在调用finalize()方法时重新让一个引用变量引用该对象,则这个对象会再次变为可达状态;否则该对象将进入不可达状态。

不可达状态:只有当一个对象处于不可达状态时,系统才会真正回收该对象所占有的资源。

 

当某个对象被其他类的类变量引用时,只有该类被销毁后,该对象才会进入可恢复状态;当某个对象被其他对象的实例变量引用时,只有当该对象被销毁后,该对象才会进入可恢复状态。

强制系统进行垃圾回收的方式

调用System类的gc()静态方法:System.gc()。

调用Runtime对象的gc()实例方法:Runtime.getRuntime().gc.()。

任何Java类都可以重写finalize()方法,在该方法中清理该对象占用的资源。

finalize()方法的特点:

永远不要主动调用某个对象的finalize()方法,该方法应该交给垃圾回收机制调用。

finalize()方法何时被调用,是否被调用具有不确定性

当JVM执行finalize()方法时出现异常时,垃圾回收机制不会报告异常,程序继续执行。

对象的软(SoftRefere)、弱(PhantomReference)和虚(WeakReference)引用。

StrongReference:这是Java程序中最常见的引用方式。

软引用:软引用通过WeakReference类来实现,当一个对象只有软引用时,它有可能被垃圾回收机制回收。对于只有软引用的对象而言,当系统内存空间足够时,他不会被系统回收,程序也可使用该对象;当系统内存空间不足时,系统可能回收他。软引用通常对于内存敏感的程序中。

弱引用:弱引用通过WeakReference实现,弱引用跟软引用很像,但弱引用的引用级别更低对于只有弱引用的对象而言,当系统垃圾回收机制运行时,他就会被立即回收。

虚引用:虚引用通过PhantomReference类实现,虚引用完全类似于没有引用。虚引用对对象本身没有太大影响,对象甚至感觉不到虚引用的存在。如果一个对象只有一个虚引用时,那么它和没有引用的效果大致相同。虚引用主要用于跟踪对象被垃圾回收的状态,虚引用不能单独使用,虚引用必须跟引用队列联合使用(ReferenceQueue)。

上述三个引用都包含一个get()方法,用于获取被它们所引用的兑现。

引用队列由java.lang.ref.ReferenceQueue类表示,它用于保存被回收后对象的引用。当联合使用软引用、弱引用和引用队列时,系统在回收被引用对象之后,将把被回收对象对应的引用添加到关联的引用队列中。与软引用和弱引用不同的是,虚引用在对象被释放之前,将把它对应的引用添加到它关联的引用队列中,这使得可以在对象被回收之前采取行动。

软引用和弱引用可以单独使用,但虚引用不能单独使用,单独使用虚引用没有太大意义。虚引用的主要作用就是跟踪对象被垃圾回收的状态,程序可以通过 检查与虚引用关联的队列中是否已经包含了该虚引用,从而了解虚引用所引用的对象是否即将被回收。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值