try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,在return前还是后?
也许你的答案是在return之前,但往更细地说,我的答案是在return中间执行(?),请看下面程序代码的运行结果:
public class TestFinally {
public static void main(String[] args) {
System.out.println(test());
}
static int test() {
int x = 1;
try {
return x;
} finally {
++x;
}
}
}
---------执行结果---------
1
运行结果是1,为什么呢?
主函数调用子函数并得到结果的过程,好比主函数准备一个空罐子,当子函数要返回结果时,先把结果放在罐子里,然后再将程序逻辑返回到主函数。所谓返回,就是子函数说,我不运行了,你主函数继续运行吧,这没什么结果可言,结果是在说这话之前放进罐子里的。 (这个比喻好费解==!)
类似题
下面的程序代码输出的结果是多少?
public class TestFinally {
public static void main(String args[]) {
TestFinally t = new TestFinally();
int a = t.get();
System.out.println(a);
}
public int get() {
try {
return 1;
} finally {
return 2;
}
}
}
---------执行结果---------
2
我可以通过下面一个例子程序来帮助我解释这个答案,从下面例子的运行结果中可以发现,try中的return语句调用的函数先于finally中调用的函数执行,也就是说return语句先执行,finally语句后执行,所以,返回的结果是2。return并不是让函数马上返回,而是return语句执行后,将把返回结果放置进函数栈中,此时函数并不是马上返回,它要执行finally语句后才真正开始返回。
在讲解答案时可以用下面的程序来帮助分析:
public class TestFinally {
public static void main(String[] args) {
System.out.println(new TestFinally().test());
}
int test() {
try {
return func1();
} finally {
return func2();
}
}
int func1() {
System.out.println("func1");
return 1;
}
int func2() {
System.out.println("func2");
return 2;
}
}
---------执行结果---------
func1
func2
2
结论:finally中的代码比return和break语句后执行
========================================================================
上面解释好费解
我的理解是:try中语句return后还得等finally语句执行,如果finally中有return,则finally中return的值替代了try中return的值,最后再返回。也就是finally一定会执行。不知道准不准确。~~
扩展:
final, finally, finalize的区别:
final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。
内部类要访问局部变量,局部变量必须定义成final类型,例如,一段代码……
finally是异常处理语句结构的一部分,表示总是执行。
finalize是Object类的一个方法,当垃圾回收器确定不存在对该对象的更多引用时,由对象的垃圾回收器调用此方法。子类重写 finalize
方法,以配置系统资源或执行其他清除。