I am working on an app that runs as a service and waits for a message. After I check the log, I find out that Android kills and restarts many processes very often! This no
One more possible reason can be due to customization of Thread.UncaughtExceptionHandler for the main thread.
By default, Android OS will show an error dialog if the process is killed because of some uncaught Exception. But you can set custom Thread.UncaughtExceptionHandler and don't propagate Exception to the default Thread.UncaughtExceptionHandler, instead you can just kill the process. Then you won't see any error messages in logs except
02-04 15:02:38.791 320 332 I ActivityManager: Process com.your.app (pid 32763) has died.
and your process will die silently.
That's convenient way if you want just store Exception and don't show error dialog that might be the case for some background processes.
It's normal, the OS does this regulary.
Why?
Every App or Service when inactive or in the background remains in memory until Android memory manager decides it is either taking up too much memory for nothing, or when another active app/service needs it. For example when you hit the home
button when you are in your e-mail app. It will return to the exact place where you were when re-opening the app. Because this app was simply paused and in some sort of hibernation mode in the memory. Unless Android needs to allocate that memory for anything else, it keeps it there.
A way to make sure the OS does not kill your service, is creating a persistant service.
You can only make your service persistent if you are developing system apps. These services will be basically un-killable, and are labeled as "PERS" in the output of the "adb shell dumpsys activity" command.
http://www.androidguys.com/2009/09/09/diamonds-are-forever-services-are-not/
But:
Please use AlarmManager
and an IntentService
, so your service does not need to be in memory except when it is doing meaningful work. This also means Android is rather unlikely to kill your service while you are in memory, and users are unlikely to kill your service because they think you are wasting memory.