Android:一段时间后重新打开应用程序时无法解释的崩溃

标签 android activity-lifecycle

我有一堆 Activity A->B->C->D,它们都运行良好。我已经在有和没有互联网、多种配置的情况下对它们进行了测试,并且我触发了屏幕在每个配置中旋转以查看它们是否会崩溃。他们没有

但是在我的 Android 手机(不是模拟器)上,应用程序在后台运行了一段时间后,如果我重新打开它(通过最近使用或通过我的主菜单),我会遇到一系列莫名其妙的崩溃。它实际上是 Activity D 崩溃,转到 C。C 崩溃,转到 B。B 崩溃,转到 A。A 崩溃,重置,然后正常打开。这让我抓狂。

在对象上总是NullPointerException,比如这些:

java.lang.RuntimeException: Unable to start activity ComponentInfo{net.getfoodie.foodie/net.getfoodie.foodie.ui.exploremenu.MenuFragmentActivity}: java.lang.NullPointerException
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2305)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2363)
at android.app.ActivityThread.access$900(ActivityThread.java:161)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1265)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:157)
at android.app.ActivityThread.main(ActivityThread.java:5356)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1265)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1081)
at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:132)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at net.getfoodie.foodie.ui.exploremenu.MenuGridAdapter.<init>(MenuGridAdapter.java:71)
at net.getfoodie.foodie.ui.exploremenu.MenuFragment.onActivityCreated(MenuFragment.java:75)
at android.support.v4.app.Fragment.performActivityCreated(Fragment.java:1794)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:967)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1126)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1108)
at android.support.v4.app.FragmentManagerImpl.dispatchActivityCreated(FragmentManager.java:1917)
at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:544)
at net.getfoodie.foodie.ui.exploremenu.MenuFragmentActivity.onStart(MenuFragmentActivity.java:89)
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1189)
at android.app.Activity.performStart(Activity.java:5436)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2278)
... 12 more 

例如,上面的错误是因为解析 sdk 中的空对象。但是这个对象已经在 Activity 的 OnCreate 期间被获取了,我猜它在重新创建 Activity 时丢失了?虽然我确保在我的 OnCreate() 中获取它,并且我测试了旋转?

您认为这是因为什么?我是否在我的应用程序生命周期中遗漏了什么?

更重要的是,我如何才能在我的 Android 模拟器上触发“activity kill/sleep”,以便重现该问题并实际尝试修复它?

最佳答案

不在屏幕上的 Activity 经常被 Android 杀死以获取内存。当通过 recents 返回到 Activity 时,最近的 Activity 将被启动,但如果它被杀死,它将没有上下文——它将获得它启动时的 Intent ,但没有静态变量或单例分配给以前的值。这会导致很多应用程序出现问题。解决方案是要么允许任何 Activity 以某种方式填写这些值,要么检测这种情况并启动适当的 Activity 并设置 CLEAR_TOP 以终止旧状态。

哦,要重现它,您只需从 Activity 管理器设置中强制停止。转到 Activity D,然后强制停止。然后通过 recents 返回。

例如,我有一个带有 LoginActivity 和 MainActivity 的应用。 MainActivity 假设 LoginActivity 已经设置了一个用户单例。我在 MainActivity 中的代码是:

public void onCreate(Bundle bundle){
  super.onCreate(bundle);
  if(User.getCurrentUser() == null){
    Intent intent = new Intent(this, LoginActivity.class);
    intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
    startActivity(intent);
    finish();
    return;
  }
  //Continue on with onCreate for this activity
}

如果未设置用户对象,这将重新启动登录 Activity 。

关于Android:一段时间后重新打开应用程序时无法解释的崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28998527/

相关文章:

java - 如何以编程方式关闭 Android 手机?

android - 如何在android上使用html5 Canvas 拖动?

android - 如何在 Android 中以编程方式选择或突出显示 TextView?

android - savedInstanceState 什么时候真正用到?

android - 代码一次又一次地请求雅虎天气服务

安卓测试 : asserting an activity transitioned to another

android - 弹出窗口中的 ListView

android - 显示具有多个航路点的两点之间的路线

android - 是否在 onActivityResult() 之前调用了 onResume()?

android - 自定义 View 的 getHeight 和 getWidth 返回 0