• 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的环境信息了

  • 相关阅读:
    隐马尔可夫模型 机器学习
    机器学习——EM算法与GMM算法
    机器学习——贝叶斯算法
    SVM算法 机器学习
    机器学习——谱聚类
    机器学习——Canopy算法
    机器学习——密度聚类
    Identity(身份)
    hyperledger fabric 结构模型学习
    fabric v1.1.0部署准备工作
  • 原文地址:https://www.cnblogs.com/haodawang/p/5967225.html
Copyright © 2020-2023  润新知