1000のタスクのプールを起動して(最大4つは並列に実行できる)、3秒以上(個別に)タイムアウトすると自動的にタイムアウトする方法?Javaタイムアウト複数のタスクを並列に実行する
ExecutorService
が役立つようですが(下の別の記事のSSCEを参照)、複数のタスクを並列で実行する方法はわかりません。future.get(3, TimeUnit.SECONDS)
は同じスレッドで実行されています1つはタスクを起動するため、複数のタスクを並行して起動する機会はありません)。
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;
public class Test {
public static void main(String[] args) throws Exception {
ExecutorService executor = Executors.newSingleThreadExecutor();
Future<String> future = executor.submit(new Task());
try {
System.out.println("Started..");
System.out.println(future.get(3, TimeUnit.SECONDS));
System.out.println("Finished!");
} catch (TimeoutException e) {
future.cancel(true);
System.out.println("Terminated!");
}
executor.shutdownNow();
}
}
class Task implements Callable<String> {
@Override
public String call() throws Exception {
Thread.sleep(4000); // Just to demo a long running task of 4 seconds.
return "Ready!";
}
}
ありがとう!
「Executors.newSingleThreadExecutor()」は使用しないでください。「Executors.newFixedThreadPool(4)」を使用してください。 'Future.get()'の呼び出しを開始する前に、それらをすべて送信してください。 –