Я пишу приложение, которое порождает несколько одновременных задач. Я использую пул потоков для реализации этого.Как остановить поток в threadpool
Возможно, произошло событие, которое делает вычисления, выполняемые в задачах недействительными. В этом случае я хотел бы остановить текущие задачи и запустить новые.
Моя проблема: Как остановить текущие задачи? Решением, которое я реализовал, является сохранение ссылки на поток задачи и вызов interrupt()
в этой теме. В демо-коде:
public class Task implements Runnable {
private String name;
private Thread runThread;
public Task(String name) {
super();
this.name = name;
}
@Override
public void run() {
runThread = Thread.currentThread();
System.out.println("Starting thread " + name);
while (true) {
try {
Thread.sleep(4000);
System.out.println("Hello from thread " + name);
} catch (InterruptedException e) {
// We've been interrupted: no more messages.
return;
}
}
}
public void stop() {
runThread.interrupt();
}
public String getName() {
return name;
}
}
И основным методом является:
public static void main(String args[]) {
executorService = Executors.newFixedThreadPool(2);
Task t1 = new Task("Task1");
Task t2 = new Task("Task2");
executorService.execute(t1);
executorService.execute(t2);
executorService.execute(new Task("Task3"));
executorService.execute(new Task("Task4"));
try {
Thread.sleep(12000);
t1.stop();
System.err.println("Stopped thread " + t1.getName());
Thread.sleep(8000);
t2.stop();
System.err.println("Stopped thread " + t2.getName());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
Это хорошее решение, или есть лучший способ, чтобы остановить запущенный поток в пул потоков?
Вынуть вилку;) – sje397