将异常信息 转换成 字符串 输出

通常输出异常信息的形式为:

e.printStackTrace();

 

通过查看Throwable类,会发现存在几个重载的方法:

    public void printStackTrace() {

        printStackTrace(System.err);

    }

 

    public void printStackTrace(PrintStream s) {

        printStackTrace(new WrappedPrintStream(s));

    }

 

    public void printStackTrace(PrintWriter s) {

        printStackTrace(new WrappedPrintWriter(s));

    }

 

所以,我们可以通过IO流将异常信息转换成字符串输出:

public class ExceptionStackTrace {
    public static void main(String[] args) throws Exception {
        try {
            String str = null;
            str.equals("AA");
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println(getStackTrace(e));
            System.out.println(getExceptionStackTrace(e));
        }
    }
    
    public static String getStackTrace(Throwable throwable) throws IOException {
        if (null == throwable) {
            return null;
        }
        
        Writer result = null;
        PrintWriter printWriter = null;
        
        try {
            result = new StringWriter();
            printWriter = new PrintWriter(result);
            throwable.printStackTrace(printWriter);
            
            return result.toString();
        }
        finally {
            printWriter.close();
            result.close();
        }
    }
    
    public static String getExceptionStackTrace(Throwable throwable) throws IOException {
        if (throwable == null) {
            return null;
        }
        
        ByteArrayOutputStream baos = null;
        PrintStream printStream = null;
        try {
            baos = new ByteArrayOutputStream();
            printStream = new PrintStream(baos);
            
            throwable.printStackTrace(printStream);
            
            return baos.toString();
        }
        finally {
            printStream.close();
            baos.close();
        }
    }
}


运行之后,输出的结果:

java.lang.NullPointerException

at com.example.reflection.Reflection.main(Reflection.java:14)

 

java.lang.NullPointerException

at com.example.reflection.Reflection.main(Reflection.java:14)

 

java.lang.NullPointerException

at com.example.reflection.Reflection.main(Reflection.java:14)

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值