我的结论是:Return是在finally中间执行。即finally语句是在try的return语句执行之后,return返回之前执行
原因如下,先看代码
public static void main(String[] args) {
System.out.println("最终i为:"+returnTest());
}
/**
*
* 在执行到return的时候:先把i=0的值拿来用,放到返回通道上,但是并没有真实返回;然后执行了i++命令使i=1;
* 然后再执行finally里面的函数,此时i=1;再finally中再执行i++命令,使i=2;
*/
private static Integer returnTest() {
int i=0;
try{
return i++;
}catch (Exception e){
e.printStackTrace();
}finally {
i++;
System.out.println("finally:"+i);
}
return -1;
}
最终结果为:
finally:2
最终i为:0
由上可知,我们在执行return的时候是先使用了原始“i=0”的值,然后再执行“i++”,最后再执行的是finally代码块里面的代码。所以会造成finally的System.out.println()输出i=2,而main方法里面的System.out.println()输出的值为i=0;
所以我们为了更加形象的表示整个过程可以把try代码块里面的return这一过程分为三步,分别是:1、try里面的return先将data放在电梯底部,但是try没有通电权限;2、待finally里面代码块执行完毕后为电梯通电;3、电梯通电后,启动运行将数据data传送出去,结束本次流程。
即: return是先把要返回的值拿来用,把要返回的data放在管道上,然后再执行finally代码块里面的代码,最后执行完毕后再返回管道中的值。
注意:一、此图仅仅是为了说明try和finally里面的return执行流程(如果都没有finally,此图不适用)。二、如果在try里面的不是return而是System.exit(0)那么此时finally是不会被执行的。因为System.exit(0)是终止Java虚拟机JVM运行,所以JVM停止运行,自然System.exit(0)后面所有代码都不会再运行。