Я пытаюсь использовать класс Java ThreadPoolExecutor
для запуска большого количества тяжелых задач с фиксированным количеством потоков. Каждая из задач имеет много мест, в течение которых она может выйти из строя из-за исключений.
Я подклассифицировал ThreadPoolExecutor
, и я переопределил метод afterExecute
, который должен предоставлять любые неперехваченные исключения, возникающие при выполнении задачи. Однако я не могу заставить его работать.
Например:
public class ThreadPoolErrors extends ThreadPoolExecutor {
public ThreadPoolErrors() {
super( 1, // core threads
1, // max threads
1, // timeout
TimeUnit.MINUTES, // timeout units
new LinkedBlockingQueue<Runnable>() // work queue
);
}
protected void afterExecute(Runnable r, Throwable t) {
super.afterExecute(r, t);
if(t != null) {
System.out.println("Got an error: " + t);
} else {
System.out.println("Everything fine--situation normal!");
}
}
public static void main( String [] args) {
ThreadPoolErrors threadPool = new ThreadPoolErrors();
threadPool.submit(
new Runnable() {
public void run() {
throw new RuntimeException("Ouch! Got an error.");
}
}
);
threadPool.shutdown();
}
}
Выход из этой программы: "Все в порядке - ситуация нормальная!" хотя только Runnable, представленный в пул потоков, генерирует исключение. Любой ключ к тому, что здесь происходит?
Спасибо!