关于Java异常的一些打印方法

关于Java异常的一些打印方法

在程序员进行Java开发时通常都会遇到出现异常的情况,使用正确的异常打印方法能够帮助程序员快速的定位问题的位置和类型。

一、常用的异常打印方法
  1. getMessage(): String
    输出异常的描述信息
  2. getLocalizedMessage()
    输出本地化的描述信息,其可被子类覆盖,缺省实现与getMessage()输出信息一致。
  3. printStackTrace()
    将异常栈打印到输出流中,此为一类方法,默认打印到console控制台,也可以显式指定输出流。
  4. fillInStackTrace()
    将当前的异常栈保存到一个Throwable中,返回这个Throwable。大部分情况下,用在保留异常栈嵌套调用的情况,尝试保留完整的异常栈,无需使用该方法。
二、简单示例
  1. 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():这是一个异常

  • 分析
    很明显此方法只是简单的将异常对象中的信息打印出来。
  1. 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()一样,都是简单的将异常对象中的信息打印出来。
  1. 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()可以打印出整个异常栈,异常栈的信息输出至默认的输出流中(通常是控制台),若是需要输出至日志文件中则需要显式指定,否则会丢失异常信息,在日志中是看不见的。
  1. 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)
  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值