首页 > 其他 > 详细

异常链

时间:2019-02-13 00:25:33      阅读:206      评论:0      收藏:0      [点我收藏+]

场景:testone抛出一个异常,testtwo接受到testone的异常后抛出一个新异常,testthree接收到testtwo的异常后再抛出一个新异常

代码如下:

package com.mpp.test;

public class TryDemoFive {
    public static void main(String[] args) {
        try{
            testTree();
        }catch (Exception e){
            e.printStackTrace();
        }

    }

    public static void testOne() throws HotelAgeException{
        throw  new HotelAgeException();
    }

    public static void testTwo() throws Exception{
        try {
            testOne();
        }catch (HotelAgeException e){
            throw new Exception("我是新产生的异常1");
        }
    }

    public static void testTree() throws Exception{
        try {
            testTwo();
        }catch (Exception e){
            throw new Exception("我是新产生的异常2");
        }
    }
}

运行结果只显示最后一个异常,造成异常的丢失

技术分享图片

解决异常链路抛出过程中丢失异常信息的问题:

修改后的代码:

package com.mpp.test;

public class TryDemoFive {
    public static void main(String[] args) {
        try{
            testTree();
        }catch (Exception e){
            e.printStackTrace();
        }

    }

    public static void testOne() throws HotelAgeException{
        throw  new HotelAgeException();
    }

    public static void testTwo() throws Exception{
        try {
            testOne();
        }catch (HotelAgeException e){
            throw new Exception("我是新产生的异常1",e);  //把testone中捕获的异常参数,加进来
        }
    }

    public static void testTree() throws Exception{
        try {
            testTwo();
        }catch (Exception e){
            Exception e1 = new Exception("我是新产生的异常2"); //新建一个异常对象
            e1.initCause(e);   //把testttwo中的异常加进来
            throw e1; //抛出异常
//            throw new Exception("我是新产生的异常2");

        }
    }
}

修改后的运行结果:

技术分享图片

总结:
技术分享图片

 

异常链

原文:https://www.cnblogs.com/mpp0905/p/10367599.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!