У меня есть приложение для Android с большим количеством действий и услуг. Если открыть другое приложение, в то время как мое приложение работает и андроид потребность ресурсы убивают мое приложение, и я получаю NullPointerException сообщения об ошибке, как это:Контроль, как андроид убивает мое приложение
07-08 18:14:48.567: E/AndroidRuntime(16300): FATAL EXCEPTION: main
07-08 18:14:48.567: E/AndroidRuntime(16300): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{icg.android.start/icg.android.web.CustomWebActivity}: java.lang.NullPointerException
07-08 18:14:48.567: E/AndroidRuntime(16300): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1880)
07-08 18:14:48.567: E/AndroidRuntime(16300): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
07-08 18:14:48.567: E/AndroidRuntime(16300): at android.app.ActivityThread.access$600(ActivityThread.java:123)
07-08 18:14:48.567: E/AndroidRuntime(16300): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
07-08 18:14:48.567: E/AndroidRuntime(16300): at android.os.Handler.dispatchMessage(Handler.java:99)
07-08 18:14:48.567: E/AndroidRuntime(16300): at android.os.Looper.loop(Looper.java:137)
07-08 18:14:48.567: E/AndroidRuntime(16300): at android.app.ActivityThread.main(ActivityThread.java:4424)
07-08 18:14:48.567: E/AndroidRuntime(16300): at java.lang.reflect.Method.invokeNative(Native Method)
07-08 18:14:48.567: E/AndroidRuntime(16300): at java.lang.reflect.Method.invoke(Method.java:511)
07-08 18:14:48.567: E/AndroidRuntime(16300): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
07-08 18:14:48.567: E/AndroidRuntime(16300): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
07-08 18:14:48.567: E/AndroidRuntime(16300): at dalvik.system.NativeStart.main(Native Method)
07-08 18:14:48.567: E/AndroidRuntime(16300): Caused by: java.lang.NullPointerException
07-08 18:14:48.567: E/AndroidRuntime(16300): at icg.guice.Dependencies.injectDependencies(Dependencies.java:238)
07-08 18:14:48.567: E/AndroidRuntime(16300): at icg.guice.GuiceActivity.<init>(GuiceActivity.java:9)
07-08 18:14:48.567: E/AndroidRuntime(16300): at icg.android.web.CustomWebActivity.<init>(CustomWebActivity.java:16)
07-08 18:14:48.567: E/AndroidRuntime(16300): at java.lang.Class.newInstanceImpl(Native Method)
07-08 18:14:48.567: E/AndroidRuntime(16300): at java.lang.Class.newInstance(Class.java:1319)
07-08 18:14:48.567: E/AndroidRuntime(16300): at android.app.Instrumentation.newActivity(Instrumentation.java:1023)
07-08 18:14:48.567: E/AndroidRuntime(16300): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1871)
Я пытался обнаружить, если андроид убивает мои действия, но не поиск я обнаружил, что там нет способ сделать это.
По крайней мере, можно избежать появления сообщения об ошибке на экране устройства? Я предпочитаю, чтобы приложение неожиданно сработало.
Благодаря
Если вы видите исключение нулевого указателя, у вас есть ошибка программирования, и вам нужно исправить ошибку. Это не Android, закрывающий вас, вы рушитесь. Вы не публикуете достаточно информации, чтобы решить ее для вас. Отправьте свой полный логарифм. –
Я вижу нулевой указатель, если система убивает мое приложение. Если я закрываю приложение, все в порядке. – Plebios
Метод 'onPause()' всегда называется до тех пор, пока Android не будет сильно убивать ваше приложение (например, вытащите батарею), поэтому вы можете использовать его для очистки приложения в случае его убийства. – Josh