在finally和catch块中抛出异常

时间:2016-12-15 09:36:20

标签: java exception try-catch-finally rethrow

对catch中抛出的异常有问题,最后阻止:

class MyExc1 extends Exception {}
class MyExc2 extends Exception {}
class MyExc3 extends MyExc2 {}

public class C1 {
    public static void main(String[] args) throws Exception {
        try {
            System.out.print(1);
            q();
        }
        catch (Exception i) {
            throw new MyExc2();
        }
        finally {
            System.out.print(2);
            throw new MyExc1();
        }
    }
    static void q() throws Exception {
        try {
            throw new MyExc1();
        }
        catch (Exception y) {
            System.out.print(3);
        }
        finally {
            System.out.print(4);
            throw new Exception();
        }
    }

}

我试过多次执行上面的代码。它每次给我不同的输出。

output 1: 1Exception in thread "main" 342test.MyExc1
at test.C1.main(C1.java:18)
output 2: 1342Exception in thread "main" test.MyExc1
at test.C1.main(C1.java:18)
output 3: 1Exception in thread "main" test.MyExc1
342 at test.C1.main(C1.java:18)
output4:  1Exception in thread "main" 34test.MyExc1
2 at test.C1.main(C1.java:18)

请解释。

1 个答案:

答案 0 :(得分:11)

您所看到的只是写入System.outSystem.err之间的竞争条件。您明确地使用1,然后是3,然后是4,然后是2来调用System.out.print,并且异常被抛出并自动转储到System.err。所以你得到的每个输出都是“1342”,其中有异常堆栈跟踪。

实际执行流程在每种情况下都是相同的 - 它只是 不同的输出。为了证明这一点,您可以将整个main方法包装在try / catch块中,该块将异常写入System.out,此时它将与所有现有{{1}同步调用,并且没有竞争条件。