如何处理未捕获的异常
john zukowski (jaz@zukowski.net) 【程序编程相关:11种衡量招聘的质量的因素 】
【推荐阅读:劝创业者——别拿自己当回事 】2004 年 8 月 【扩展信息:中国人和中国式管理 】总裁, jz ventures, inc. 跟踪无法预期的运行时异常可能是一件又慢又费力的事情,只获得默认线程名称与堆栈跟踪通常是不够的.在驯服 tiger 这一期专栏中,java 开发人员 john zukowski 向您展示了如何通过替代默认行为来定制输出.他还对比了通过细分 threadgroup 定制输出的老方法与通过提供自己的 uncaughtexceptionhandler 定制输出的新方法.虽然我们不想创建在无法预期时抛出运行时异常的程序,但这种情况还是会发生——尤其是第一次运行复杂程序时.通常是使用默认行为.打印堆栈溢出与结束线程的生命来处理这些异常.
从哪里发现默认行为?每个线程都属于一个由 java.lang.threadgroup 类表示的线程组.顾名思义,线程组允许您将线程组合在一起.您可能是为了方便而将线程组合,例如,一个线程池中的所有线程都属于组 x,而另一个池的所有线程则属于组 y,或者是为了访问控制而将线程进行组合.组 x 中的线程无权访问或改变组 y 中的线程,除非它们都在同一线程组内(或在一个子组内).
在 tiger 之前,threadgroup 类提供了一种处理未捕获异常的方法:threadgroup 的 uncaughtexception() 方法.如果异常不是 threaddeath,则将线程的名称与堆栈回溯(stack backtrace)发送到 system.err.但是 tiger 添加了另一种方法:thread.uncaughtexceptionhandler 接口.细分 threadgroup 或安装该新接口的实现都允许您更改默认行为.我们将对 tiger 之前与之后提供的方法都进行研究.
使用 threadgroup 的定制行为
发生未捕获的异常时,默认行为是将堆栈溢出打印输出到系统错误(system.err)中,如清单 1 中所示.不需要使用任何命令参数来启动程序.清单 1. 线程溢出示例 public class simpledump { public static void main(string args[]) { system.out.println(args[0]); } }不使用任何参数运行该程序将生成清单 2 中的输出.尽管它不是一个很长的堆栈跟踪,但它是一个完整的堆栈跟踪.
清单 2. 默认线程溢出输出 exception in thread "main" java.lang.arrayindexoutofboundsexception: 0 at simpledump.main(simpledump.java:3)正如 java 平台的许多东西一样,如果不喜欢默认行为,您可以对其进行更改.... 下一页