首先我们要知道finally为必执行项,它对应的代码块无论出现异常与否都要执行
try {
return 1;
}finally {
return 2;
}
小伙伴们先看一下这一题的返回值为多少?
答案为2 -----先执行try中内容,返回值为1,再执行finally返回值变为2,要知道finally为必执行项,不管try中写了什么都要接着执行finally中的内容。
try {
return 1;
}finally {
try {
return 2;
}finally {
return 3;
}
}
这一题与上一题同一原理,返回值为3,我就不讲了,自己看去吧。
int i = 7;
try {
return i++;
}finally {
i++;
System.out.println("finally中的i是" + i);
}
这一题稍微复杂了一点,先进入到try代码块中,获取i的值是7,由于++在i的后面 , 所以JVM先标记i的值为7,然后再进行自增运算,i变成8 *,在要return标记值7的时候,发现还有finally存在,所以会先挂起return 7的操作 ,继续执行finally代码块中的代码,i++ 变成9 ,然后finally打印9,然后再返回7(return 7) , 所以最终结果是7和9
Person p = new Person();
try {
p.setName("刘翔");
p.setAge(19);
return p;
}finally {
p = new Person();
p.setName("姚明");
p.setAge(23);
}
因为返回的是对象,是同一个地址. * 在finally中修改了同一个地址的属性值,所以结果是姚明这个对象。
String str;
try {
str = "abc";
return str;
}finally {
str = "def";
}
}
答案为 abc ,这题考察顺带考察了String的知识点,String表示的变量为常量,放入方法区的字符串常量池中,所以try中的return 指向的str为abc的地址,然后执行finally中的str发现它变成def,又换了地址,而try中的return依然指向原地址,所以返回值为abc。
本文详细解析了Java中的异常处理机制,重点讨论了`try-finally`块中的返回值问题。通过实例分析,展示了在不同情况下`try`和`finally`中返回值的执行顺序和最终返回的结果。同时,探讨了`finally`块对于对象引用的影响,以及在涉及字符串常量时的特殊性。
984

被折叠的 条评论
为什么被折叠?



