异常对象的 printStackTrace() 方法用于打印异常的跟踪栈信息,根据 printStackTrace() 方法的输出结果,开发者可以找到异常的源头,并跟踪到异常一路触发的过程。
下面是用于测试 printStackTrace 的程序:
运行结果为:
上图记录了应用程序中执行停止的各个点。
第一行的信息详细显示了异常的类型和异常的详细信息。接下来跟踪栈记录程序中所以的异常发生点,各行显示被调用方法中执行的停止位置,并标明类、类中的方法名、与故障点对应的文件的行。一行行往下看,跟踪栈总是最内部的被调用方法逐渐上传,直到最外部业务操作的起点,通常是程序的入口 main 方法或 Thread 类的 run 方法(多线程的情形)。
下面程序示范了多线程程序中发生异常的情形:
运行上面程序,得到下面结果:
从上图可以看出,程序在 Thread 的 run 方法中出现了 ArithmeticException 异常,该异常的源头是 ThreadExceptionTest 的 secondMethod 方法,位于 ThreadExceptionTest.java 文件的27 行。这个异常传播到 Thread 类的 run 方法就会结束(如果该异常没有得到处理,将会导致线程终止运行)
Java 的异常跟踪栈
最新推荐文章于 2022-07-12 11:38:04 发布