Фрагмент уже добавлен IllegalStateException

Я использую этот метод в своем контейнере Activity, чтобы показать BFrag

public void showBFrag()
{
    // Start a new FragmentTransaction
    FragmentTransaction fragmentTransaction = mFragmentMgr.beginTransaction();

    if(mBFrag.isAdded())
    {
        Log.d(LOG_TAG, "Show() BFrag");
        fragmentTransaction.show(mBFrag);   
    }
    else
    {
        Log.d(LOG_TAG, "Replacing AFrag -> BFrag");
        fragmentTransaction.replace(R.id.operation_fragments_frame, mBFrag);
    }

    // Keep the transaction in the back stack so it will be reversed when backbutton is pressed
    fragmentTransaction.addToBackStack(null);

    // Commit transaction
    fragmentTransaction.commit();        
}

Я вызываю его из своего контейнера Activity; впервые:

  • попадает в оператор else, и mBFrag заменяет mAFrag.

Затем я нажимаю кнопку возврата:

  • , и операция отменяется (отображается mAFrag, но… удаляется ли mBFrag?).

Затем я иду вперед. снова, вызвав showBFrag () из того же Activity:

  • , и он снова вводится в оператор else. (так что я могу сделать вывод, что mBFrag НЕ ДОБАВЛЯЕТСЯ)
  • , но я получил уже добавленный фрагмент IllegalStateException ... (так почему вместо этого он не попал в оператор if?)

Итак:

  1. Почему метод isAdded () не возвращает TRUE, если я получаю фрагмент, уже добавленный IllegalStateException ??
  2. Удаляет ли операция popBackStack полностью ранее добавленные фрагменты?
  3. Какое поведение я неправильно понимаю стоя?

РЕДАКТИРОВАТЬ: Вот полная информация об исключении.

06-07 12:08:32.730: ERROR/AndroidRuntime(8576): java.lang.IllegalStateException: Fragment already added: BFrag{40b28158 id=0x7f0c0085}
06-07 12:08:32.730: ERROR/AndroidRuntime(8576):     at android.app.BackStackRecord.doAddOp(BackStackRecord.java:322)
06-07 12:08:32.730: ERROR/AndroidRuntime(8576):     at android.app.BackStackRecord.replace(BackStackRecord.java:360)
06-07 12:08:32.730: ERROR/AndroidRuntime(8576):     at android.app.BackStackRecord.replace(BackStackRecord.java:352)
06-07 12:08:32.730: ERROR/AndroidRuntime(8576):     at myPackageName.containerActivity.showBFrag() // This line: "fragmentTransaction.replace(R.id.operation_fragments_frame, mBFrag);"
53
задан Axel M. Garcia 7 June 2011 в 00:25
поделиться