在发现 Executors.newCachedThreadPool() 在Java 1.6上运行 Executors.newCachedThreadPool() (以及从Eclipse中)吞下 Runnable.run() 方法中的异常之后,我试图想出一种方法来捕获这些但不向我的所有 Runnable 实现添加throw / catch .
API建议覆盖 FutureTask.setException() 应该有助于此:
使此未来报告以给定throwable为原因的ExecutionException,除非已设置或已取消此Future . 在计算失败时,run方法在内部调用此方法 .
但是这个方法似乎没有被调用(运行调试器显示异常被 FutureTask 捕获,但 setException isn 't called). I'已写入以下程序来重现我的问题:
public class RunTest {
public static void main(String[] args) {
MyFutureTask t = new MyFutureTask(new Runnable() {
@Override
public void run() {
throw new RuntimeException("Unchecked exception");
}
});
ExecutorService service = Executors.newCachedThreadPool();
service.submit(t);
}
}
public class MyFutureTask extends FutureTask {
public MyFutureTask(Runnable r) {
super(r, null);
}
@Override
protected void setException(Throwable t) {
super.setException(t);
System.out.println("Exception: " + t);
}
}
我的主要问题是:如何捕获FutureTask中引发的异常?为什么不叫 setException ?
另外我想知道为什么 Thread.UncaughtExceptionHandler 机制没有被 FutureTask 使用,这有什么理由吗?