/*
* 2018年3月28日10:56:48
* 代码目的:
* 演示异常重新抛出时,调用栈信息,如果不做处理,直接抛出原来的异常对象的引用,则
* 调用栈信息不会更新。
* 核心主题:
* 如果只是把当前异常对象重新抛出,那么printStackTrace方法显示的将是原来抛出点的调用栈信息,
* 而非重新抛出点的信息。要想更新这个消息,可以调用fillInStackTrace()方法,
* 这将返回一个Throwable对象,它是通过把当前调用栈信息填入原来那个异常对象而建立的。
*
* */
//: exceptions/Rethrowing.java
// Demonstrating fillInStackTrace()
public class Rethrowing {
public static void f() throws Exception {
System.out.println("originating the exception in f()");
throw new Exception("thrown from f()");
}
public static void g() throws Exception {
try {
f();
} catch(Exception e) {
System.out.println("Inside g(),e.printStackTrace()");
e.printStackTrace(System.out);
//重抛异常会把异常抛给上一级环境中的异常处理程序
//如果只是把当前对象重新抛出,那么printStackTrace()方法显示的
//将是原来的异常抛出点的调用栈信息,而并不是重新抛出点的信息。
//这可以从代码输出结果看出。
throw e;
}
}
public static void h() throws Exception {
try {
f();
} catch(Exception e) {
System.out.println("Inside h(),e.printStackTrace()");
e.printStackTrace(System.out);
//如果想要更新这个信息,可以调用fillInStackTrace()方法,这将返回一个Throwable对象,
//它是通过把当前调用栈信息填入原来的那个异常对象而建立的。
throw (Exception)e.fillInStackTrace();
}
}
public static void main(String[] args) {
try {
g();
} catch(Exception e) {
System.out.println("main: printStackTrace()");
e.printStackTrace(System.out);
}
try {
h();
} catch(Exception e) {
System.out.println("main: printStackTrace()");
e.printStackTrace(System.out);
}
}
} /* Output:
originating the exception in f()
Inside g(),e.printStackTrace()
java.lang.Exception: thrown from f()
at Rethrowing.f(Rethrowing.java:7)
at Rethrowing.g(Rethrowing.java:11)
at Rethrowing.main(Rethrowing.java:29)
main: printStackTrace()
java.lang.Exception: thrown from f()
at Rethrowing.f(Rethrowing.java:7)
at Rethrowing.g(Rethrowing.java:11)
at Rethrowing.main(Rethrowing.java:29)
originating the exception in f()
Inside h(),e.printStackTrace()
java.lang.Exception: thrown from f()
at Rethrowing.f(Rethrowing.java:7)
at Rethrowing.h(Rethrowing.java:20)
at Rethrowing.main(Rethrowing.java:35)
main: printStackTrace()
java.lang.Exception: thrown from f()
at Rethrowing.h(Rethrowing.java:24)
at Rethrowing.main(Rethrowing.java:35)
*///:~