Android process produces logcat “has died” message very often.

前端 未结 2 1097
执笔经年
执笔经年 2020-12-15 22:25

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

相关标签:
2条回答
  • 2020-12-15 23:03

    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.

    0 讨论(0)
  • 2020-12-15 23:18

    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.

    0 讨论(0)
提交回复
热议问题