zoukankan      html  css  js  c++  java
  • 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的环境信息了

  • 相关阅读:
    [结题报告]10235 Simply Emirp Time limit: 3.000 seconds
    [杭电ACM]1720A+B Coming
    [结题报告]10041 Vito's Family Time limit: 3.000 seconds
    mysqlvarchar、text 类型到底能存储多大字符?
    mysql项目更换数据源为oralce后项目调整
    Oracle创建定时任务执行函数
    IOS手机访问网页window.location.href跳转新页面第一次可以第二次报错失效
    logrotate日志分割
    查找一批设备的在线情况
    pkill 用法例子
  • 原文地址:https://www.cnblogs.com/haodawang/p/5967225.html
Copyright © 2011-2022 走看看