IllegalStateException в FragmentManager -> restoreAllState (): не удалось найти активный фрагмент с индексом -1 - PullRequest
0 голосов
/ 06 февраля 2019

Я использую AppCompatActivity с фрагментами, и, скорее всего, при изменении ориентации экрана возникает следующая ошибка:

Вызвано java.lang.IllegalStateException Не удалось найти активный фрагмент с индексом -1

Ошибка возникает только у 0,1% пользователей.На этой активности я показываю расширенную DialogFragment с setRetainInstance(true).Я не мог воспроизвести проблему сам!

Может быть, вы знаете, как избежать этой ошибки?

Трассировка стека:

android.support.v4.app.FragmentManagerImpl.restoreAllState (FragmentManager.java:3047)
android.support.v4.app.FragmentController.restoreAllState (FragmentController.java:152)
android.support.v4.app.FragmentActivity.onCreate (FragmentActivity.java:330)
android.support.v7.app.AppCompatActivity.onCreate (AppCompatActivity.java:84)
(see code 2) com.example.BaseActivity.onCreate (BaseActivity.java:76)
(see code 1) com.example.authorization.AuthorizationActivity.onCreate (AuthorizationActivity.java:39)
android.app.Activity.performCreate (Activity.java:6772)
android.app.Instrumentation.callActivityOnCreate (Instrumentation.java:1119)
android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2715)
android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:2823)
android.app.ActivityThread.handleRelaunchActivity (ActivityThread.java:4655)
android.app.ActivityThread.-wrap19 (ActivityThread.java)
android.app.ActivityThread$H.handleMessage (ActivityThread.java:1551)
android.os.Handler.dispatchMessage (Handler.java:102)
android.os.Looper.loop (Looper.java:154)
android.app.ActivityThread.main (ActivityThread.java:6349)
java.lang.reflect.Method.invoke (Method.java)
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:893)
com.android.internal.os.ZygoteInit.main (ZygoteInit.java:783)

Код 1(из AuthorizationActivity.java):

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState); // THIS LINE

    setContentView(R.layout.activity_authorization);

    db_user = new UserDatabase(this);
    db_wedding = new WeddingDatabase(this);


    if (savedInstanceState == null) {
        getSupportFragmentManager().beginTransaction().replace(R.id.authorization_container, new AuthorizationMainFragment()).commit();
    }

    boolean show = getPreferences().getBoolean(SettingsWeddingFragment.KEY_RESTORE_FILL, false);
    if (show) {
        db_wedding.showFillDefaultDataMessage(runnable);
    }
}

Код 2 (из BaseActivity.java):

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState); // THIS LINE

    Helper.setBootTimeDifference(this);

    resetTitle();

    preferences = PreferenceManager.getDefaultSharedPreferences(this);
    Alert.newInstance(this);

    if (!(BaseActivity.this instanceof SplashActivity)) {
        BaseActivity.incAdCounter();
    }
}

@Override
public void onBackPressed() {
    if (getSupportFragmentManager().getBackStackEntryCount() > 0 ) {
        if (isVisible()) {
            getSupportFragmentManager().popBackStack();
            getSupportFragmentManager().beginTransaction().replace(R.id.authorization_container, new AuthorizationMainFragment()).commit();
        }
    } else {
        super.onBackPressed();
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...