问题描述
- JAVA finally内的处理在什么情况下会影响到返回值?
-
例子如下,返回结果不同,前两个方法为finally没处理前的结果,而后一个方法的返回值为处理后的结果。请问这是为什么。public class Test {
public static void main(String[] args) {
System.out.println(test1());
System.out.println(test2());
System.out.println(test3());
}private static int test1()
{
int n=1;
try
{
return n;
}
finally
{
n=n+1;
}
}private static String test2()
{
String x = new String();
x="xxx";
try
{
return x;
}
finally
{
x=x+"a";
}
}private static StringBuffer test3()
{
StringBuffer b = new StringBuffer();
b.append("xxx");
try
{
return b;
}
finally
{
b.append("a");
}
}
}
解决方案
首相finally{}的执行时间是在try{}中间的return返回的中间或者是之后。准确的说是在return语句的中间,但是可以理解为return之后。所以第一种情况的结果必然是1,因为此时的n是1。
第二种情况是String,这里要理解String的特性,String是不可变的,是内容不可以变的,但是应用是可变的。在finally执行之前已经return了String的一个引用了,此String的引用指向的是xxx。所以即使后面的String所指向的内容已经变化但是对之前那个不造成影响。
第三种情况是,StringBuffer,String与Stringbuffer之间的不同是,String是内容不可以变,而Stringbuffer是内容可变。所以返回的StringBuffer的引用之后,在finally里面对b所指向的引用内容进行了改变,虽然引用b的地址值没有改变,但是到main方法里面时,b所指向的内容已经变化了,所以打印出来的结果也是变化后的结果。
对于这个try{}finally{}的执行顺序理解之后,加上对每个数据类型的特点有比较深的理解就可以理解这类问题了。
希望我的回答对你有帮助