如题,
一个方法中 try{}finally{} 语句块内都有return语句时,方法的执行顺序是怎样的?
当方法finally中对try中要返回的值进行操作后,返回值是否会变?
以下是我的理解,先看代码:
public class Test {
public int test() {
try {
return 0;
} finally {
return 1;
}
}
public static void main(String[] args) throws Exception {
Test t = new Test();
System.out.println(t.test()); // 输出一直是1
}
}
从执行结果来看,是执行了finally里的代码,那么try里的代码是否执行了,答案是执行了,JVM在执行时,先执行try里的代码,但是并没有马上返回,而是在要返回时,跳去执行了finally里的代码,finally里的return直接结束了方法,所以没来得及跳回try执行try的返回。
public class Test {
public int test() {
int x = 1;
try {
return x;
} finally {
++x;
}
}
public static void main(String[] args) throws Exception {
Test t = new Test();
System.out.println(t.test());//输出一直是1
}
}
从执行结果来看,在try执行时,已经准备好了要返回的值,并存储在了JVM中的某个地方(暂时存储返回值的地方),然后跳去执行finally,在finally中使x+1,这时x里的值变成了2,然后返回try继续执行刚才暂停的动作(即 return ),注意,这里的x就是同一个空间,但是try要返回的不是x空间中的值,而是刚才在JVM中暂存的值,所以这里的返回值是1。
public class Test {
public int test() {
int x = 1;
try {
return x++;
} finally {
return ++x;
}
}
public static void main(String[] args) throws Exception {
Test t = new Test();
System.out.println(t.test());//输出3
}
}
这里输出3,是因为在try中执行x++使x的值变成了2,要返回是跳去执行了finally,在finally中返回i++,即 i=3,然后结束了方法,没来得及回到try执行返回。