Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Difference between TimerTask and Executors.newScheduledThreadPool(1)

I need to schedule some work to be done in the future. I can do it in 2 ways:

  1. Create a TimerTask and execute timer.schedule(...);

  2. Use Executors.newScheduledThreadPool(1):

    ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
    ScheduledFuture <?> scheduleHandle = scheduler.schedule(pushExternalRunnable,  
            runScheduleDate.getTime() - now.getTime(), TimeUnit.MILLISECONDS);
    

What is the difference between these 2 ways of scheduling the work in the future?

like image 571
Basanth Roy Avatar asked May 24 '11 14:05

Basanth Roy


2 Answers

The biggest difference is that the Timer will schedule all of its tasks on a single background thread. The ExecutorService, on the other hand, will create new threads (if necessary) to run the tasks (up to the size of the pool you specify, at which point tasks will be queued.)

like image 113
dlev Avatar answered Sep 23 '22 11:09

dlev


One other difference is if there is an uncaught exception. In case of a Timer, the background thread is terminated but it is not brought back up. With a ScheduledExecutor (even with a single thread configuration), the ScheduledExecutor can continue after an uncaught exception. It tries to ensure the desired number of threads are running to process the tasks.

The ScheduledExecutor also produces a future in case you want to interact with the progress.

like image 20
sjlee Avatar answered Sep 20 '22 11:09

sjlee