Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

ExecutorService awaitTermination gets stuck

I made a fixed size thread pool with Executors.newFixedThreadPool(2), and I executed 10 Runnable objects. I set breakpoints and traced through the execution. However, fixedSizeThreadPool.awaitTermination() does not allow me to continue even though all the tasks are done.

Basically:

ExecutorService fixedThreadPool = Executors.newFixedThreadPool(2);
for (int i = 0; i < 10; ++i) {
    fixedSizeThreadPool.execute(myRunables[i]);
}
try {
    fixedSizeThreadPool.awaitTermination(timeout, timeoutUnits);
} catch (Exception e) { }
System.out.println("done!");

But this always gets stuck on awaitTermination. What's wrong?

like image 503
Kevin Avatar asked Aug 14 '11 19:08

Kevin


2 Answers

As Peter pointed out, shutdown() must be called first.

source: javadoc

like image 149
Paul Bellora Avatar answered Oct 27 '22 10:10

Paul Bellora


You could also use ExecutorService#invokeAll. It blocks until all tasks are done or the timeout is reached. It's a little cleaner than using shutdown, if your ExecutorService contains other tasks as well especially scheduled tasks. These would also be affected by a call to shutdown.

like image 22
emboss Avatar answered Oct 27 '22 10:10

emboss