Android FragmentManager BackStackRecord.run throw NullPointerException

使用片段时,我有时会遇到以下异常:

FATAL EXCEPTION: main
java.lang.NullPointerException
    at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:591)
    at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1416)
    at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:420)
    at android.os.Handler.handleCallback(Handler.java:615)
    at android.os.Handler.dispatchMessage(Handler.java:92)
    at android.os.Looper.loop(Looper.java:137)
    at android.app.ActivityThread.main(ActivityThread.java:4745)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:511)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
    at dalvik.system.NativeStart.main(Native Method)

当 调用 through 时,会发生异常,当它试图从管理器中删除片段时。run()BackStackRecordexecPendingTransactions()

case OP_REMOVE: {
  Fragment f = op.fragment;
  f.mNextAnim = op.exitAnim; <----
  mManager.removeFragment(f, mTransition, mTransitionStyle);
}
break;

我似乎无法弄清楚究竟是什么原因造成的?我认为这与删除碎片时未正确清理碎片的回堆栈有关。


答案 1

回答我自己的问题:

当您调用 FragmentTransaction.remove(null); 和 FragmentTransaction.commit();

编辑:而且,就像Twice Circled和ShinyuX在评论中指出的那样;当调用 show(null)add(null)attach(null)detach(null) 方法时,可能还会隐藏(null)

调用后,事务将在 FragmentManager 中排队。因此,在显式调用 后处理操作时,或者当 FragmentManager 队列线程调用它时,它会抛出一个 .commit()FragmentManager.executePendingTransactions()NullPointerException

在我的情况下,我在全局对象中维护片段状态。在那里,我检查了片段是否显示,然后删除了可见的片段。但是,由于我启动了一个新的 FragmentActivity,因此这些状态在不可见时仍设置为 true。所以这是一个设计错误。

除了修复设计错误之外,解决方案很简单:在删除片段之前检查是否返回。FragmentManager.findFragmentByTag()null


答案 2

发生这种情况的一个原因是调用

getSupportFragmentManager().beginTransaction().remove(fragment)

而 为空fragment


推荐