Java面向对象系列[v1.0.0][异常跟踪栈]

异常的跟踪栈信息

异常对象的printStackTrace()方法用于打印异常的跟踪栈信息,根据printStackTrace()方法的输出结果,开发者可以找到异常的源头,并跟踪到异常一路触发的过程

class SelfException extends RuntimeException
{
	SelfException(){}
	SelfException(String msg)
	{
		super(msg);
	}
}
public class PrintStackTraceTest
{
	public static void main(String[] args)
	{
		firstMethod();
	}
	public static void firstMethod()
	{
		secondMethod();
	}
	public static void secondMethod()
	{
		thirdMethod();
	}
	public static void thirdMethod()
	{
		throw new SelfException("自定义异常信息");
	}
}

异常从thirdMethod方法开始触发,传到secondMethod方法,再传到firstMethod方法,最后传到main方法,在main方法终止,这个过程就是Java的异常跟踪栈
只要异常没有被完全捕获(包括异常没有被捕获,或异常被处理后重新抛出了新异常),异常从发生异常的方法逐渐向外传播,首先传给该方法的调用者,该方法调用者在此传给其调用者…直到最后传给main方法,如果main方法依然没有处理该异常,JVM会中止该程序,并打印异常的跟踪栈信息



在命令行执行上边的代码:

D:\BaiduNetdiskDownload\CrazyJava\codes\10\10.5>java PrintStackTraceTest
Exception in thread "main" SelfException: 自定义异常信息
        at PrintStackTraceTest.thirdMethod(PrintStackTraceTest.java:37) ==异常源头==
        at PrintStackTraceTest.secondMethod(PrintStackTraceTest.java:33) ==第二个==
        at PrintStackTraceTest.firstMethod(PrintStackTraceTest.java:29) ==第三个==
        at PrintStackTraceTest.main(PrintStackTraceTest.java:25) ==main方法==
  • 第一行信息详细显示了异常的类型和异常的详细信息
  • 接下来跟踪栈记录程序中所有的异常发生点,各行显示被调用方法中执行的停止位置,并标明类、类中的方法名、与故障点对应的文件的行
  • 跟踪栈总是最内部的被调用方法逐渐上传,直到最外部业务操作的起点,通常就是程序的入口main方法或者Thread类的run方法(多线程的情况)
public class ThreadExceptionTest implements Runnable
{
	public void run()
	{
		firstMethod();
	}
	public void firstMethod()
	{
		secondMethod();
	}
	public void secondMethod()
	{
		var a = 5;
		var b = 0;
		var c = a / b;
	}
	public static void main(String[] args)
	{
		new Thread(new ThreadExceptionTest()).start();
	}
}

命令行执行代码结果为

D:\BaiduNetdiskDownload\CrazyJava\codes\10\10.5>java ThreadExceptionTest
Exception in thread "Thread-0" java.lang.ArithmeticException: / by zero
        at ThreadExceptionTest.secondMethod(ThreadExceptionTest.java:27)
        at ThreadExceptionTest.firstMethod(ThreadExceptionTest.java:21)
        at ThreadExceptionTest.run(ThreadExceptionTest.java:17)
        at java.base/java.lang.Thread.run(Thread.java:834)

这表明程序在Thread的run方法中出现了ArithmeticException异常,这个异常的源头是ThreadExceptionTest的secondMethod方法,位于THreadExceptionTest.java文件的27行,异常传播到Thread类的run方法就会结束

虽然printStackTrace()方法很方便的用于追踪异常,但最后发布的程序中应尽量避免使用它,而应该对捕获的异常进行适当的处理,而不是打印出来

猜你喜欢

转载自blog.csdn.net/dawei_yang000000/article/details/106810294