【发布时间】:2016-11-06 01:03:49
【问题描述】:
我正在尝试追查一次非常罕见的崩溃(数千次会话中的一次)。我有一个 Activity,在它的 onCreate 覆盖期间,它创建了一些片段,但没有显示或附加任何片段:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);
setContentView(R.layout.activity_main);
mainMenuFragment = new MainMenuFragment();
locationFragment = new LocationFragment();
mainPresenter = new MainPresenter(this);
}
在这段代码中,我还创建了一个“MainPresenter”,它来自一个包含我们所有业务逻辑的库。 Presenter 是从 Fragments 的 onAttach 方法中使用的:
@Override
public void onAttach(Activity activity) {
super.onAttach(activity);
MainActivity mainActivity = (MainActivity) activity;
mainPresenter = mainActivity.getMainPresenter();
mainPresenter.refreshUI();
}
问题是,我很少在 onAttach 中收到 null ptr 异常。在极少数情况下,片段的 onAttach 是否可能在活动的 onCreate 完成之前执行(即 mainPresenter 为空)?
更新
这是导致崩溃的调用堆栈的一部分,以防万一:
android.app.ActivityThread.performLaunchActivity (ActivityThread.java:3253)
android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:3349)
android.app.ActivityThread.handleRelaunchActivity (ActivityThread.java:5383)
android.app.ActivityThread.access$1200 (ActivityThread.java:221)
android.app.ActivityThread$H.handleMessage (ActivityThread.java:1800)
android.os.Handler.dispatchMessage (Handler.java:102)
android.os.Looper.loop (Looper.java:158)
android.app.ActivityThread.main (ActivityThread.java:7225)
java.lang.reflect.Method.invoke (Method.java)
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:1230)
com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1120)
【问题讨论】:
-
本周我遇到了这个确切的问题。我发现,如果我通过 Android Studio 的 Android Monitor 选项卡在后台终止应用程序后重新启动应用程序,这种情况会更常见。如果您需要可靠的复制品进行测试,这可能会很有用。
-
@stkent - 谢谢,我会试一试