Difference between AlarmManager and ScheduledExecutorService
ScheduledExecutorService
runs in your application process. If application process dies, none of the scheduled tasks will run. Hence the need for Service
(so your process lives beyond Activities active part of lifecycle).
While AlarmManager
is critical system service that runs all the time. And if your application scheduled something and was killed, then AlarmManager
may start application again (via PendingIntent
).
And the last major difference that no one mentioned here is that AlarmManager
knows about WakeLock
s and power management. This means that AlarmManager
may wake up Android device at specified time to run scheduled task. While ScheduledExecutorService
knows nothing about power management and will only start task when device is not in deep sleep (i.e. it can simply miss the time).
ScheduledExecutorService
will only work if you have some component, such as a Service
, running all of the time. Hence, it should only be used in cases where the component would be in memory for other reasons, adding value to the user. Having a component be in memory solely to watch the clock tick by is wasteful and one of the reasons why users attack developers with task killers and such.
AlarmManager
is an OS-supplied system service. It can start up a component when the time rolls around. Hence, you do not need to have the component running.
In my case, I need to run a little bit of code to check for new data every night and create a new notification if there is new data.
This is a clear scenario for AlarmManager
.
I think ScheduledExecutorService
is tied to your process and will not work in case your process gets killed. In contrast AlarmManager
is managed by the OS so it works even if your application is not running.