Android:一段时间后重新打开应用程序时无法解释的崩溃
Android: Unexplained crashes when the app is reopened after a while
我有一堆活动 A->B->C->D,它们都运行良好。我已经在有和没有互联网、多种配置的情况下对它们进行了测试,并且我触发了屏幕在每个配置中旋转以查看它们是否会崩溃。他们没有
但是在我的 Android phone(不是模拟器)上,一段时间后应用程序在后台,如果我重新打开它(通过最近使用或通过我的主菜单),我遇到了一系列无法解释的崩溃。字面意思是 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.access0(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",以便重现问题并实际尝试修复它?
不在屏幕上的活动经常被 Android 杀死以便记忆。当通过 recents 返回到 Activity 时,最近的 activity 将被启动,但如果它被杀死,它将没有上下文——它将获得启动时的意图,但没有静态变量或分配给先前值的单例。这会导致很多应用程序出现问题。解决方案是允许任何 activity 以某种方式填写这些值,或者检测这种情况并启动适当的 activity 并设置 CLEAR_TOP 以终止旧状态。
哦,要重现它,您只需从活动管理器设置中强制停止。转到activityD,然后强行停止。然后 return 通过 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。
我有一堆活动 A->B->C->D,它们都运行良好。我已经在有和没有互联网、多种配置的情况下对它们进行了测试,并且我触发了屏幕在每个配置中旋转以查看它们是否会崩溃。他们没有
但是在我的 Android phone(不是模拟器)上,一段时间后应用程序在后台,如果我重新打开它(通过最近使用或通过我的主菜单),我遇到了一系列无法解释的崩溃。字面意思是 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.access0(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",以便重现问题并实际尝试修复它?
不在屏幕上的活动经常被 Android 杀死以便记忆。当通过 recents 返回到 Activity 时,最近的 activity 将被启动,但如果它被杀死,它将没有上下文——它将获得启动时的意图,但没有静态变量或分配给先前值的单例。这会导致很多应用程序出现问题。解决方案是允许任何 activity 以某种方式填写这些值,或者检测这种情况并启动适当的 activity 并设置 CLEAR_TOP 以终止旧状态。
哦,要重现它,您只需从活动管理器设置中强制停止。转到activityD,然后强行停止。然后 return 通过 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。