应用程序通常通过抛出一个异常来响应另一个异常。实际上,第一个异常导致第二个异常。了解一个异常何时导致另一异常可能非常有帮助。链式异常(Chained Exceptions)可以帮助程序员做到这一点。
以下是支持链式异常的Throwable方法和构造器。
Throwable getCause()Throwable initCause(Throwable)Throwable(String, Throwable)Throwable(Throwable)
initCause和Throwable构造器的参数Throwable,是导致当前异常的异常。getCause返回导致当前异常的异常,initCause设置当前异常的原因。
以下示例显示如何使用链式异常。
try {} catch (IOException e) {throw new SampleException("Other IOException", e);}
在此示例中,当捕获到IOException时,将创建一个附加了原始原因的新异常SampleException,并将异常链抛出到下一个更高级别的异常处理程序。
访问堆栈跟踪信息
现在,让我们假设更高级别的异常处理程序希望以其自己的格式转储堆栈跟踪。
定义: 一个堆栈跟踪(stack trace)提供有关当前线程的执行历史记录的信息,并列出发生异常时,被调用的类和方法的名称。堆栈跟踪是一个有用的调试工具,通常会在抛出异常时利用它。
以下代码显示如何在异常对象上调用getStackTrace方法。
catch (Exception cause) {StackTraceElement elements[] = cause.getStackTrace();for (int i = 0, n = elements.length; i < n; i++) {System.err.println(elements[i].getFileName()+ ":" + elements[i].getLineNumber()+ ">> "+ elements[i].getMethodName() + "()");}}
Logging API
下一个代码段记录了catch块内发生异常的位置。但是,与其手动解析堆栈跟踪并将输出发送到System.err(),不如使用java.util.logging包中的日志记录工具将输出发送到文件中 。
try {Handler handler = new FileHandler("OutFile.log");Logger.getLogger("").addHandler(handler);} catch (IOException e) {Logger logger = Logger.getLogger("package.name");StackTraceElement elements[] = e.getStackTrace();for (int i = 0, n = elements.length; i < n; i++) {logger.log(Level.WARNING, elements[i].getMethodName());}}
