私のアプリケーションではScheduledExecutorServiceを使用していますが、スケジュールされたタスクを処理するために1つのスレッドのみが生成されます。これは、ScheduledExecutorServiceが保留中のタスクを処理するためのスレッドを生成しないためですか?
これは、予想される「run()1」の後に「run()2」...「run()10」が続くのではなく、「run()1」のみを出力するコードスニペットです。
public class App {
public static void main(String[] args) {
int N = 10;
Runnable runner = new Runnable() {
public void run() {
foo();
}
};
for (int i = 0; i < N; i++) {
executor.schedule(runner, i, TimeUnit.MILLISECONDS);
}
}
private static void foo() {
System.out.println("run() " + (++n));
synchronized (executor) {
try {
executor.wait();
} catch (InterruptedException ex) {
Logger.getLogger(App.class.getName()).log(Level.SEVERE, null, ex);
}
}
System.out.println("finished()");
}
private static Logger logger = Logger.getLogger(App.class.getName());
private static int n = 0;
private static ScheduledExecutorService executor = Executors.newScheduledThreadPool(1);
}