Java 未捕获的全局异常处理程序
我有一个应用程序,需要编写一个自定义全局未捕获的异常处理程序。我已经阅读了所有的stackoverflow线程,每个线程都缺少一个清晰而简单的示例来说明如何实现它。
请考虑以下简单示例:
public static void log(String msg) throws Exception {
String logPath = "/application/logs/java.log";
Calendar c = new GregorianCalendar();
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String now = format.format(c.getTime());
PrintWriter out = new PrintWriter(new BufferedWriter(new FileWriter(logPath, true)));
out.println(now + " " + msg);
out.close();
}
它引发一个标准异常,它只是一个标准输出。我如何实现我自己的异常,它通过简单的方法覆盖标准异常,例如将错误输出到日志文件中?显然,实际的应用程序要大得多,我们正在谈论未捕获的异常,这就是为什么try/catch块不是选项的原因。
更新:如果你能用一个非常清晰的完整例子来回答,因为我发现了几十个例子,就像@RamonBoza提供的例子一样,但我不知道如何实现它们,这就是这个问题的全部内容。
更新2:所以我试图测试下面答案中唯一的例子,它显然不起作用。我创建了一个新的类文件“MyRunnable”,并将代码粘贴在其中:
package mypackage;
Thread t = new Thread(new MyRunnable());
t.setUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {
public void uncaughtException(Thread t, Throwable e) {
LOGGER.error(t + " throws exception: " + e);
}
});
t.start();
//outside that class
class MyRunnable implements Runnable(){
public void run(){
throw new RuntimeException("hey you!");
}
}
不用说,我得到了一堆错误。怎么会有什么东西在课堂之外呢?
更新3:这是最终有效的解决方案:
package mypackage;
public class MyClass {
public static void main(String[] args) throws Exception {
Thread.currentThread().setUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {
public void uncaughtException(Thread t, Throwable e) {
StringWriter sw = new StringWriter();
e.printStackTrace(new PrintWriter(sw));
String stacktrace = sw.toString();
System.out.println(stacktrace);
}
});
//main method code
}
//Rest of the methods here
}