问题:
在java中,如果try语句中有return,finally语句会不会执行呢? 执行!
finally语句和try中的return哪个先执行呢? finally中的语句先执行!
finally语句会不会改变return语句中变量的值呢? 不会!
面试原题:
try {} 里有一个return语句,那么紧跟在这个try后的finally {}里的代码会不会被执行?
什么时候被执行?
在return前还是后?
详细解答:
public class TryTest{
public static void main(String[] args){
System.out.println(test());
}
private static int test(){
int num = 10;
try{
System.out.println("try");
num += 80;
return num ;
}catch(Exception e){
System.out.println("error");
}finally{
if (num > 20){
num = 100;
System.out.println("num>20 : " + num);
}
System.out.println("finally");
}
return num;
}
}
输出结果:
try
num>20 : 100
finally
90
从输出结果中,我们可以看出:
1、finally中的语句块执行了
2、finally中的语句块先于try中的return语句执行
3、finally中对num的修改并没有改变return 语句中num的值
详细分析:
- 当代码执行到return num;时,并不是直接将num返回了出去,而是将num保留了起来(因为还有一个finally语句块没有执行!)并且这个保留,就是值传递性质的一个保留,也就是保留的是num的一个副本(复制体),我这里先叫他num1吧!
- 接下来执行finally语句块,finally中给num赋了新的值100,这时num=100了,但是这并没有影响num的复制体num1的值!保留起来的num1值还是90!
- 这个时候执行完了finally,正式将保留起来的num1返回出去,于是,整个函数的返回结果就是90
- 这个num的副本(复制体)保留的地方是哪儿呢?我查了半天,有个应该靠谱的说法,保留在函数栈中,但具体保留的区域叫什么,我也不知道,还请知情大佬指教一下!
借用大神的一个例子和一张图会看的更清晰一些:
public static void main(String[] args) {
int result = test();
System.out.println(result);
}
public static int test() {
int t = 0;
try {
return t;
} finally {
++t;
}
}
非常感谢大神的讲解LiuZh,感恩的小心心