java 异常链

有的时候我们会用printStackTrace来打印异常栈,有可能我们会在处理异常的时候同时又抛出一个异常。
自定义两个异常

class MyException1 extends Exception{
	
} 


class MyException2 extends Exception{
	MyException2(Throwable throwable){
		super(throwable);
	}
	MyException2(){
		super();
	}
}

MyException2 调用了父类的构造方法,目的是为了能够传递一个cause进来。

接下来定义一个A 类,并在他的f()方法里调用g()方法,然后在f处理g里抛出的异常的时候再次抛出一个异常

class A{
	public void f() throws MyException2{
		try {
			g();
		} catch (MyException1 e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
			throw new MyException2();
		}
	}
	public void g() throws MyException1{
		throw new MyException1();
	}
}

在catch里我们又抛出了一个MyException2的异常,这里我们先调用它的无参构造方法

接下来我们在main里跑一下

public class Main {
	public static void main(String[] args) {
		A a = new A();
		try {
			a.f();
		} catch (MyException2 e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

看一下控制台

我们可以明显的发现异常栈的内容变少了。这是因为MyException2对MyException1的环境一无所知。

那么如果MyException2 能够持有MyException1的环境信息,这样做起来就十分方便了,并且也形成了一条链,我们也成为异常链。
唯一要修改的就是调用MyException2的有参构造函数,把MyException1当作cause传递进去,这样的话我们就能获取到MyException1的信息了。

class A{
	public void f() throws MyException2{
		try {
			g();
		} catch (MyException1 e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
                        //这里做了修改
			throw new MyException2(e);
		}
	}
	public void g() throws MyException1{
		throw new MyException1();
	}
}

我们再次运行


我们会发现我们已经可以持有MyException1的环境信息了

posted @ 2016-10-16 17:44  浩大王  阅读(462)  评论(0编辑  收藏  举报