java---异常体系的try -catch-final小坑

背景

当代码抛出一个异常时 , 就会终止方法中剩余代码的处理, 并退出这个方法的执行 。 如果方法获得了一些本地资源, 并且只有这个方法自己知道 , 又如果这些资源在退出方法之前必须被回收, 那么就会产生资源回收问题 。 java中采用final来处理善后工作。

直接上小栗子:

public static void main(String[] args) {
       int i=1;
        try {
            Class<?> aClass = Class.forName("");
            i=3;
        }catch (ClassNotFoundException a){
            i=4;
        }finally {
            i=5;
        }
        System.out.println(i);
}

这个显而易见答案是5

如果代码稍作修改:

 public void abc(int i){

        try {
            Class<?> aClass = Class.forName("");
            i=3;
        }catch (ClassNotFoundException a){
            i=4;
            return;
        }finally {
            i=5;
        }
    }

答案是几,是否有犹豫,还是5

        当 finally 子句包含 return 语句时,将会出现一种意想不到的结果 „ 假设利用 return语句从 try 语句块中退出。 在方法返回前 , finally子句的内容将被执行。 如果 finally 子句中也有一个 return 语句, 这个返回值将会覆盖原始的返回值。

public static int f ( int n )
{
    try{
        int r = n * n ;
        return r ;
    }finally{
        if ( n = 2 ) 
        return 0 ;
    }
}

如果调用 f ( 2 ) , 那么 try 语句块的计算结果为 r = 4 , 并执行 return 语句然而 , 在方法真正返回前, 还要执行finally 子句 。 finally 子句将使得方法返回 0 , 这个返回值覆盖了原始的返值 4。

上一篇:PHP设计模式—解释器模式


下一篇:CSS文本不换行并且对溢出文本进行处理