刚才在一个人的blog中看到一个关于java中的finally里的语句在什么时候执行的文章,感觉还是挺有收获的,现在就把他的大致意思以及自己的验证和大家分享下
在java的API中,关于的finally的介绍是无论异常处理try-catch语句是否抛出异常,finally中的语句都会执行。因此我们可以在finally语句中做很多必须要做的操作,比如流关闭、链接关闭等。
但是有个问题,如果try最后return语句,那finally里的语句又是什么时候去执行呢?
这个问题先不回答,我们先看下面几个测试用例,看完之后也许你就知道了点什么。
/**
*@Description: 关于finally的测试
*/
package cn.lulei.test;
public class Test {
public int testFinally(){
int x = 1;
try{
return x;
} catch (Exception e) {
e.printStackTrace();
return -1;
} finally {
x++;
System.out.println("x = " + x);
}
}
public static void main(String[] args) {
System.out.println("testFinally:" + new Test().testFinally());
}
}
输出结果是:
x = 2
testFinally:1
/**
*@Description: 关于finally的测试
*/
package cn.lulei.test;
public class Test {
@SuppressWarnings("finally")
public int testFinally(){
try{
return function1();
} catch (Exception e) {
e.printStackTrace();
return -1;
} finally {
return function2();
}
}
private int function1(){
System.out.println("function1");
return 1;
}
private int function2(){
System.out.println("function2");
return 2;
}
public static void main(String[] args) {
System.out.println("testFinally:" + new Test().testFinally());
}
}
输出结果是:
function1
function2
testFinally:2
看完这两个测试用例,是不是感觉finally中的语句好在try中的return语句之前,又好像在try中的return语句之后。其实finally中的语句更确切的说是在return中间运行的,这里也许你会说,return语句明显就是一步,哪里来的中间,不错,是没有中间,但是如果从整体来看,也许就“有了”,下面就简单分析下:
A函数调用B函数并得到结果的过程,就好比A函数准备好了一个空罐子,当B函数要返回结果时,先把结果放在罐子里①,然后再将程序逻辑返回到A函数②。所谓的返回,就是B函数说,我不运行了,你A函数继续运行吧。这时我们再回头看一下上面的测试用例,第一个没有什么好说的,B把1放到罐子里,又运行了若干操作,最后告诉A函数继续运行,所以得到上图的结果;第二个也是一样,B函数先把1放到罐子里,然后继续运行一些操作,这时B发现该把2放到罐子里的,因此又把罐子里的值换成2,最后告诉A函数继续运行,所以A函数得到的返回值是2而不是1。所以实际上,当罐子里面有值的时候,B并不是立即通知A,而是等finally里面的语句全部执行完之后,采去通知A的,这样解释return就相当于有中间了。