当异常被抛出,通常方法的执行将作一个陡峭的非线性的转向。依赖于方法是怎样编码的,异常甚至可以导致方法过早返回。这在一些方法中是一个问题。例如,如果一个方法打开一个文件项并关闭,然后退出,你不希望关闭文件的代码被异常处理机制旁路。finally关键字为处理这种意外而设计。
finally块一般用来关闭物理资源(数据库连接,网络连接,磁盘文件等),这些物理资 源必须显式关闭。除非在try块、catch块中调用了退出虚拟机的方法 ( System.exit(0); ),否则不管在try块、catch块中执行怎样的代码,出现怎样的 情况,异常处理的finally块一定会被执行
下面的例子显示了3种不同的退出方法。每一个都执行了finally子句:
package com.ls.yc;
import java.util.Calendar;
// Demonstrate finally.
class Demo {
// Through an exception out of the method.
static void A() {
try {
System.out.println("inside A");
throw new RuntimeException("demo");
} finally {
System.out.println("A's finally");
}
}
// Return from within a try block.
static void B() {
try {
System.out.println("inside B");
return;
} finally {
System.out.println("B's finally");
}
}
// Execute a try block normally.
static void C() {
try {
System.out.println("inside C");
} finally {
System.out.println("C's finally");
}
}
public static void main(String args[]) {
try {
A();
} catch (Exception e) {
System.out.println("Exception caught");
}
B();
C();
}
}
注意:如果finally块与一个try联合使用,finally块将在try结束之前执行。
下面是上述程序产生的输出:
inside A
A's finally
Exception caught
inside B
B's finally
inside C
C's finally