两者有一些区别,我想你可以运行看看这个例子,就可以理解了
public class Test {
public static void main(String[] args) {
Test test = new Test();
System.out.println(test.test1());
System.out.println(test.test2());
}
public int test1() {
int book = 1;
try {
return book;
} finally {
book = 2;
}
}
public int test2() {
int book;
try {
book = 1;
} finally {
book = 2;
}
return book;
}
}
这个例子的运行结果是
1
2
为什么在finally中都是改变的同一个变量,两者的结果会不一样呢。其实你要看它翻译成jvm的byte code就可以很好的理解了。在test1
中实际上在return之前book变量已经被从stack中弹出,然后被压入一个return的stack准备弹出了,这个时候再跳入finally
中的代码,无论它怎么改变book的值,但是因为最终返回的是return的stack中的最顶上的那个值,所以也不会对最终结果造成改变,因为这是两个不同的堆栈。
如果你对test1
中的代码稍加改进,把finally
中的代码改成return 2
,那么test1的结果也是2了。这时候并不是优先执行finally
中的return 2
这么简单(虽然你也可以简单的这么理解),但实际上是它把2压入了return的stack,最后再跳回try中的return语句,这时候return的堆栈最顶上的值已经变成2了,所以return出来就是2了。