关于Java异常的一些打印方法
在程序员进行Java开发时通常都会遇到出现异常的情况,使用正确的异常打印方法能够帮助程序员快速的定位问题的位置和类型。
一、常用的异常打印方法
- getMessage(): String
输出异常的描述信息 - getLocalizedMessage()
输出本地化的描述信息,其可被子类覆盖,缺省实现与getMessage()输出信息一致。 - printStackTrace()
将异常栈打印到输出流中,此为一类方法,默认打印到console控制台,也可以显式指定输出流。 - fillInStackTrace()
将当前的异常栈保存到一个Throwable中,返回这个Throwable。大部分情况下,用在保留异常栈嵌套调用的情况,尝试保留完整的异常栈,无需使用该方法。
二、简单示例
- getMessage()
- 代码示例:
public static void main(String[] args) {
System.out.println("哈哈哈哈哈");
try {
throw new Exception("这是一个异常");
} catch (Exception e) {
System.out.println("e.getMessage():" + e.getMessage());
}
}
- 运行结果:
哈哈哈哈哈
e.getMessage():这是一个异常
- 分析
很明显此方法只是简单的将异常对象中的信息打印出来。
- getLocalizedMessage()
- 代码示例
public static void main(String[] args) {
System.out.println("哈哈哈哈哈");
try {
throw new Exception("这是一个异常");
} catch (Exception e) {
System.out.println("e.getLocalizedMessage():" + e.getLocalizedMessage());
}
}
- 运行结果
哈哈哈哈哈
e.getLocalizedMessage():这是一个异常
- 分析
getLocalizedMessage()和getMessage()一样,都是简单的将异常对象中的信息打印出来。
- printStackTrace()
- 代码示例
public static void main(String[] args) {
System.out.println("哈哈哈哈哈");
try {
throw new Exception("这是一个异常");
} catch (Exception e) {
e.printStackTrace();
}
}
- 运行结果:
哈哈哈哈哈
java.lang.Exception: 这是一个异常
at com.test.Test.main(Test.java:11)
- 分析
从结果中可以看出来,printStackTrace()可以打印出整个异常栈,异常栈的信息输出至默认的输出流中(通常是控制台),若是需要输出至日志文件中则需要显式指定,否则会丢失异常信息,在日志中是看不见的。
- fillInStackTrace()
- 代码示例:
public class FillInExceptionTest {
public static void main(String[] args) {
FillInExceptionTest fit = new FillInExceptionTest();
try {
fit.outerMehtod();
} catch (Exception e) {
System.out.println("\n========================");
e.printStackTrace();
}
}
public void innerMethod() throws Exception {
throw new Exception("I got exception in an inner method.");
}
public void outerMehtod() throws Exception {
try {
//invoke inner method.
innerMethod();
} catch (Exception e) {
e.printStackTrace();
throw (Exception)e.fillInStackTrace();
}
}
}
- 运行结果:
java.lang.Exception: I got exception in an inner method.
at com.test.FillInExceptionTest.innerMethod(FillInExceptionTest.java:18)
at com.test.FillInExceptionTest.outerMehtod(FillInExceptionTest.java:26)
at com.test.FillInExceptionTest.main(FillInExceptionTest.java:9)
========================
java.lang.Exception: I got exception in an inner method.
at com.test.FillInExceptionTest.outerMehtod(FillInExceptionTest.java:29)
at com.test.FillInExceptionTest.main(FillInExceptionTest.java:9)
- 分析
fillInStackTrace()只提取了当下的异常栈信息,而非完整的异常栈信息,若是需要将最外层完整的异常栈打印出来只需要将
throw (Exception)e.fillInStackTrace(); 替换为 throw e;即可- 运行结果
java.lang.Exception: I got exception in an inner method.
at com.test.FillInExceptionTest.innerMethod(FillInExceptionTest.java:18)
at com.test.FillInExceptionTest.outerMehtod(FillInExceptionTest.java:26)
at com.test.FillInExceptionTest.main(FillInExceptionTest.java:9)
========================
java.lang.Exception: I got exception in an inner method.
at com.test.FillInExceptionTest.innerMethod(FillInExceptionTest.java:18)
at com.test.FillInExceptionTest.outerMehtod(FillInExceptionTest.java:26)
at com.test.FillInExceptionTest.main(FillInExceptionTest.java:9)