Final+Finally+Finalize
Final
final 关键字是一种访问控制标识符。可用于修饰变量、方法、类。
final 变量:(变量、成员或参数)
当发生参数传递或变量被初始化时,final修饰的变量在程序后续执行过程中不能被改变。若变量被定义为final,并且未被初始化时,必须先经由初始化块或构造器将其初始化后才能使用。
final 方法:
被定义为final的方法不能被子类重写。
final 类:
当类被定义为final时,该类将不能派生子类。类被定义为final时,将使得其中的成员和方法被隐示定义为final。
Finally
用于显示回收try块里打开的物理资源(例如数据库连接、网络连接和磁盘文件等等)。
<span style="background:yellow">Java的垃圾回收机制不会回收任何物理资源,只能回收堆内存中对象所占用的内存。</span>
完整的Java异常处理语法如下:
try
{
...
}
catch(SubException e)
{
...
}
catch(SubException2 e)
...
finally
{
//资源回收
...
}
异常处理语法结构规则:
- 只有try块是必需的,如果没有try块,则不能有后面的catch块和finally块
- catch块和finally块都是可选的,但catch块和finally块至少出现其中之一,也可同时出现
- 可以有多个catch块,捕获父类异常的catch块必须位于捕获子类异常的后面
- 不能只有try块,catch块和finally块都没有
- 多个catch块必须位于try块之后,finally块必须位于所有的catch块之后
- 不要在finally块中使用return或throw等导致方法终止的语句,一旦如此。将会导致try块、catch块中的return、throw语句失效
不管try块中的代码是否出现异常,也不管哪一个catch块被执行,甚至在try块或catch块中执行了return语句,finally块总会被执行。不过若在try块或catch块中调用了退出虚拟机的方法,则finally块中的代码不会执行。
Finalize
在垃圾回收机制回收某个对象所占用的内存之前,通常要求程序调用适当的方法来清理资源,在没有明确指定清理资源的情况下,Java提供了默认机制来清理该对象的资源,这个机制就是finallize()
方法。
finalize()方法是定义在Object类中的实例方法。
protected void finalize() throws Throwable
当finalize()方法返回后,对象消失,垃圾回收机制开始执行。方法原型中的throws Throwable
表示该方法可抛出任何类型的异常。
若程序终止之前没有进行垃圾回收,则不会调用失去引用对象的finalize()方法来清理资源。 垃圾回收机制何时调用对象的finalize()方法是完全透明的。
下面介绍一下Java中引用的类型:
对象的软、弱和虚引用
-
强引用(StrongReference)
Java程序中最常见的应用方式。程序创建一个对象,并把这个对象赋给一个引用变量,程序通过该引用变量来操作实际的对象。当一个或一个以上的引用变量所引用时,它处于可达状态,不可能被垃圾回收机制回收。
-
软引用(SoftReference)
通过SoftReference类实现。当一个对象只有软引用时,它可能会被垃圾回收机制回收。当系统内存空间足够时,被软引用的对象不会被系统回收,程序也可使用该对象;当空间不足时,系统可能会回收它。
-
弱引用(WeakReference)
通过WeakReference类实现。弱引用和软引用很相像,但弱引用的引用级别更低。当系统垃圾回收机制运行时,不管系统内存是否足够,总会回收被该引用引用的对象。
-
虚引用(PhantomReference)
通过PhantomReference类实现。虚引用类似于完全没有引用。虚引用对对象本身没有太大的影响,对象甚至感觉不到虚引用的存在。虚引用主要用于跟踪对象被垃圾回收的状态,虚引用必须和引用队列(ReferenceQueue)联合使用。
上述三个引用都包含了一个get()方法,用于获取被它们引用的对象。
引用队列(ReferenceQueue):
用于保存被回收的对象的引用。
- 当联合使用软引用、弱引用和引用队列时,系统在回收被引用的对象之后,将把被回收的对象对应的引用添加到关联的引用队列之中。
- 虚引用在对象被释放之前,将把它对应的虚引用添加到它关联的引用队列中,使得可以在对象被回收之前采取行动。