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

时间:2015-03-11 22:24:16

标签: android activity-lifecycle

我有一系列活动A-> B-> C-> D并且它们都运行良好。我已经测试过它们有无互联网,多种配置,我已触发屏幕旋转每一个,看看它们是否会崩溃。他们没有

但是在我的Android手机(不是模拟器)上,经过一段时间该应用程序在后台,如果我打开它(通过最近或我的主菜单),我得到一系列无法​​解释的崩溃。它实际上是活动D崩溃,转向C. C崩溃,转向B. B崩溃,转到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中的null对象。但是在活动的OnCreate期间已经获取了该对象,我猜它在重新创建活动时会丢失?虽然我确保我在OnCreate()中获取它,然后测试了旋转?

您认为这是由于什么原因造成的?我在应用生命周期中遗漏了什么吗?

更重要的是,如何在我的Android模拟器上触发“活动杀死/睡眠”,以便我可以重现该问题并实际尝试修复它?

1 个答案:

答案 0 :(得分:2)

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

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

作为示例 - 我有一个具有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
}

如果未设置User对象,这将重新启动登录活动。