1700448965
1700448966
}
1700448967
1700448968
class Person{
1700448969
1700448970
private String name;
1700448971
1700448972
/*name的getter/setter方法省略*/
1700448973
1700448974
}
1700448975
1700448976
此方法的返回值永远都是name为李四的Person对象,原因是Person是一个引用对象,在try代码块中的返回值是Person对象的地址,finally中再修改那当然会是李四了。
1700448977
1700448978
(2)屏蔽异常
1700448979
1700448980
为什么明明把异常throw出去了,但main方法却捕捉不到呢?这是因为异常线程在监视到有异常发生时,就会登记当前的异常类型为DataFormatException,但是当执行器执行finally代码块时,则会重新为doStuff方法赋值,也就是告诉调用者“该方法执行正确,没有产生异常,返回值是1”,于是乎,异常神奇的消失了,其简化代码如下所示:
1700448981
1700448982
public static void doSomething(){
1700448983
1700448984
try{
1700448985
1700448986
//正常抛出异常
1700448987
1700448988
throw new RuntimeException();
1700448989
1700448990
}finally{
1700448991
1700448992
//告诉JVM:该方法正常返回
1700448993
1700448994
return;
1700448995
1700448996
}
1700448997
1700448998
}
1700448999
1700449000
public static void main(String[]args){
1700449001
1700449002
try{
1700449003
1700449004
doSomething();
1700449005
1700449006
}catch(RuntimeException e){
1700449007
1700449008
System.out.println(“这里永远都不会到达!”);
1700449009
1700449010
}
1700449011
1700449012
}
1700449013
1700449014
上面finally代码块中的return已经告诉JVM:doSomething方法正常执行结束,没有异常,所以main方法就不可能获得任何异常信息了。这样的代码会使可读性大大降低,读者很难理解作者的意图,增加了修改的难度。
[
上一页 ]
[ :1.700448965e+09 ]
[
下一页 ]