java try throw exception finally 遇上 return break continue造成异常丢失

    如下所示,是一个java笔试题,考察的是抛出异常之后,程序运行结果,但是这里抛出异常,并没有捕获异常,而是通过finally来进行了流程控制处理。

package com.xxx.test;

public class ExceptionFlow {
    public static void main(String[] args) {
        try {
            System.out.println("hello " + func());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static int func() {
        int a = 0;
        for (int i = 0; i < 3; i++) {
            try {
                throw new RuntimeException("xx");
            } finally {
                 continue;
            }
        }
        return a;
    }
}

    运行程序,打印结果如下所示:

 

    这里结果有些出人意料,并没有打印异常信息,其实就是try finally遇到了continue,导致异常信息丢失。如果这里,我们稍微改变一下,把finally中的continue注释,再来看看结果:

 

    这次打印了异常信息。

   下面再来看看另一个例子:

package com.xxx.test;
public class ExceptionDemo {
    public static void main(String[] args) {
        try {
            func();
            System.out.println("A");
        } catch (Exception e) {
            System.out.println("C");
        }
        System.out.println("D");
    }

    public static void func() {
        try {
            throw new Exception();
        } finally {
            System.out.println("B");
        }
    }
}

    这里要求写出程序运行结果。

    这道题的答案其实就是编译不通过,如下所示:

 

    这里需要在func方法签名上声明抛出异常。方法签名上添加了抛出异常,这里就编译成功,运行结果是B C D。

    这里其实也可以不用在方法签名上进行声明,直接把异常改成自定义异常RuntimeException("xx"),最终程序运行结果也是一样的。 

    这里我们按照第一个题目的思路,把finally中添加return信息,这时候,运行结果会变为B A D。

   因为异常信息丢失,所以在调用func()的地方,进行try catch的时候,就不会有异常信息,那么程序就会按照正常的流程运行。