Android 嵌套碎片崩溃

Android 嵌套碎片崩溃,android,android-fragments,Android,Android Fragments,我正在处理嵌套片段,并使用childfragmentmanager处理内部片段。当操作系统重新创建片段时,我遇到以下错误(我通过在应用程序后台强制销毁活动来测试这一点) 当我向片段中添加以下行时,崩溃不会发生 @Override public void onSaveInstanceState(Bundle outState){ setTargetFragment(null, -1); super.onSaveInstanceState(outState); } 我不确定这是什么

我正在处理嵌套片段,并使用childfragmentmanager处理内部片段。当操作系统重新创建片段时,我遇到以下错误(我通过在应用程序后台强制销毁活动来测试这一点)

当我向片段中添加以下行时,崩溃不会发生

@Override
public void onSaveInstanceState(Bundle outState){
    setTargetFragment(null, -1);
    super.onSaveInstanceState(outState);
}
我不确定这是什么原因造成的。以前有人遇到过这个问题吗。下面是堆栈跟踪

    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.debug/com.ui.MainActivity}: java.lang.IllegalStateException: Fragment no longer exists for key android:target_state: index 2
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
        at android.app.ActivityThread.access$800(ActivityThread.java:144)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:135)
        at android.app.ActivityThread.main(ActivityThread.java:5221)
        at java.lang.reflect.Method.invoke(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:372)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
 Caused by: java.lang.IllegalStateException: Fragment no longer exists for key android:target_state: index 2
        at android.support.v4.app.FragmentManagerImpl.getFragment(FragmentManager.java:584)
        at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:883)
        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.dispatchCreate(FragmentManager.java:1912)
        at android.support.v4.app.Fragment.performCreate(Fragment.java:1776)
        at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:913)
        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.dispatchCreate(FragmentManager.java:1912)
        at android.support.v4.app.FragmentActivity.onCreate(FragmentActivity.java:266)
        at android.support.v7.app.ActionBarActivity.onCreate(ActionBarActivity.java:98)
        at com.ui.MainActivity.onCreate(MainActivity.java:68)
        at android.app.Activity.performCreate(Activity.java:5933)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
            at android.app.ActivityThread.access$800(ActivityThread.java:144)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5221)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)

尝试在嵌套片段中使用
getParentFragment()
,而不是使用
setTargetFragment()
getTargetFragment()

可以发布stacktrace吗,用stacktraceDid更新了我的帖子你找到导致崩溃的原因了吗?我发现这个线程很有用,原因是目标片段和片段本身不是由同一个FragmentManager管理的。在您的情况下,我猜ChildFragmentManager会尝试恢复由默认FragmentManager管理的目标片段?
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.debug/com.ui.MainActivity}: java.lang.IllegalStateException: Fragment no longer exists for key android:target_state: index 2
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
        at android.app.ActivityThread.access$800(ActivityThread.java:144)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:135)
        at android.app.ActivityThread.main(ActivityThread.java:5221)
        at java.lang.reflect.Method.invoke(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:372)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
 Caused by: java.lang.IllegalStateException: Fragment no longer exists for key android:target_state: index 2
        at android.support.v4.app.FragmentManagerImpl.getFragment(FragmentManager.java:584)
        at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:883)
        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.dispatchCreate(FragmentManager.java:1912)
        at android.support.v4.app.Fragment.performCreate(Fragment.java:1776)
        at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:913)
        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.dispatchCreate(FragmentManager.java:1912)
        at android.support.v4.app.FragmentActivity.onCreate(FragmentActivity.java:266)
        at android.support.v7.app.ActionBarActivity.onCreate(ActionBarActivity.java:98)
        at com.ui.MainActivity.onCreate(MainActivity.java:68)
        at android.app.Activity.performCreate(Activity.java:5933)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
            at android.app.ActivityThread.access$800(ActivityThread.java:144)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5221)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)