Что-то пошло не так с жизненным циклом действия, а не нормальное поведение при нажатии кнопки домой или переключения задач

Что-то не так в моем коде. Обычно жизненный цикл активности - при запуске приложения: onCreate -> onStart -> onResume - при закрытии приложения: onPause -> onStop -> onDestroy - нажатие кнопки «Домой» или кнопки переключения задач: onPause -> onStop - возврат к уже открытому приложению из другого приложения: onStart -> onResume

Но по какой-то причине мое приложение также вызывает onDestroy, когда я нажимаю кнопку «Домой» или кнопку переключения задач, и вызывает onCreate, когда я возвращаюсь в уже открытое приложение.

В моем приложении есть 2 Activites: - LoginActivity, который должен появиться первым, если никто не вошел в систему или если нажата кнопка выхода из системы - MainActivity для обработки основных функций.

Пожалуйста, помогите мне определить, что вызывает такое ненормальное поведение жизненного цикла.

Спасибо!

Основная деятельность:

public class MainActivity extends AppCompatActivity
    implements NavigationView.OnNavigationItemSelectedListener {

public Helper helper = new Helper(this);

public static final String SP_DATA = "SP_DATA";
public static final String FB_LOGIN_STATUS = "FB_LOGIN_STATUS";
public static final String FLRT = "FLRT";

public SharedPreferences sharedPreferences;

public FragmentManager fragmentManager = getFragmentManager();

@Override
protected void onCreate(Bundle savedInstanceState) {
    Log.d(FLRT, "onCreate");
    helper.makeToast("onCreate");

    sharedPreferences = getSharedPreferences(SP_DATA, MODE_PRIVATE);
    boolean bAlreadyLoggedIn = sharedPreferences.getBoolean(FB_LOGIN_STATUS, false);

    if (bAlreadyLoggedIn) {
        Log.d(FLRT, "Already logged in");
    }
    else {
        Log.d(FLRT, "Not logged in");

        Intent intent = new Intent(MainActivity.this, LoginActivity.class);
        startActivity(intent);
    }

    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);


    showFragment(new FirstFragment(),"FirstFragment");

    Button btnLogout = (Button) findViewById(R.id.btnLogout);

    btnLogout.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {

            logout();

            showActivity(MainActivity.this, LoginActivity.class);
        }
    });

    FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
    fab.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                    .setAction("Action", null).show();
        }
    });

    DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
            this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
    drawer.setDrawerListener(toggle);
    toggle.syncState();

    NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
    navigationView.setNavigationItemSelectedListener(this);
}

private void showActivity(Context context_fromActivity, Class<?> class_toActivty){
    Intent intent = new Intent(context_fromActivity, class_toActivty);
    //intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);

    startActivity(intent);

    MainActivity.this.finish();
}

private void logout() {
    Log.d(FLRT, "Logging out...");

    sharedPreferences = getSharedPreferences(SP_DATA, MODE_PRIVATE);
    SharedPreferences.Editor editor = sharedPreferences.edit();
    editor.putBoolean(FB_LOGIN_STATUS, false);
    editor.commit();
}

@Override
public void onBackPressed() {
    DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
    if (drawer.isDrawerOpen(GravityCompat.START)) {
        drawer.closeDrawer(GravityCompat.START);
    } else if (getFragmentManager().getBackStackEntryCount() > 1 ){
        getFragmentManager().popBackStack();
    } else {
        super.onBackPressed();
    }
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();

    //noinspection SimplifiableIfStatement
    if (id == R.id.action_settings) {
        return true;
    }

    return super.onOptionsItemSelected(item);
}

@SuppressWarnings("StatementWithEmptyBody")
@Override
public boolean onNavigationItemSelected(MenuItem item) {
    switch (item.getItemId()) {
        case R.id.nav_first_layout:
            showFragment(new FirstFragment(), "FirstFragment");
            break;
        case R.id.nav_second_layout:
            showFragment(new SecondFragment(), "SecondFragment");
            break;
        case R.id.nav_third_layout:
            showFragment(new ThirdFragment(), "ThirdFragment");
            break;
        case R.id.nav_share:

            break;
        case R.id.nav_send:

            break;
    }

    DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
    drawer.closeDrawer(GravityCompat.START);
    return true;
}

private void showFragment(Fragment fragment, String sFragmentTAG) {
    FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();

    if (fragmentManager.findFragmentByTag(sFragmentTAG) != null) {
        Log.d(FLRT, "Fragment found, using existing one: " + sFragmentTAG);
        fragment = fragmentManager.findFragmentByTag(sFragmentTAG);
    }

    fragmentTransaction.replace(R.id.fragmentContainer, fragment, sFragmentTAG);
    fragmentTransaction.addToBackStack(null);
    fragmentTransaction.commit();
}

@Override
protected void onStart() {
    super.onStart();
    Log.d(FLRT, "onStart");
    helper.makeToast("onStart");
}

@Override
protected void onResume() {
    super.onResume();
    Log.d(FLRT, "onResume");
    helper.makeToast("onResume");
}

@Override
protected void onPause() {
    super.onPause();
    Log.d(FLRT, "onPause");
    helper.makeToast("onPause");
}

@Override
protected void onStop() {
    super.onStop();
    Log.d(FLRT, "onStop");
    helper.makeToast("onStop");
}

@Override
protected void onDestroy() {
    super.onDestroy();
    Log.d(FLRT, "onDestroy");
    helper.makeToast("onDestroy");
}
}

Войти

public class LoginActivity extends AppCompatActivity {

public static final String SP_DATA = "SP_DATA";
public static final String FB_LOGIN_STATUS = "FB_LOGIN_STATUS";
public static final String FLRT = "FLRT";

public SharedPreferences sharedPreferences;

private Button btn_start;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_login);

    btn_start = (Button) findViewById(R.id.btn_start);

    btn_start.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {

            login();

            showActivity(LoginActivity.this, MainActivity.class);;
        }
    });
}

private void showActivity(Context context_fromActivity, Class<?> class_toActivty){
    Intent intent = new Intent(context_fromActivity, class_toActivty);
    //intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);

    startActivity(intent);

    LoginActivity.this.finish();
}

private void login() {
    Log.d(FLRT, "Logging in...");

    sharedPreferences = getSharedPreferences(SP_DATA, MODE_PRIVATE);
    SharedPreferences.Editor editor = sharedPreferences.edit();
    editor.putBoolean(FB_LOGIN_STATUS, true);
    editor.commit();
}
}

person lpasztor    schedule 19.04.2016    source источник
comment
Иногда, если на устройстве мало памяти, ОС убивает фоновые приложения. в вашем устройстве может быть проблема с памятью. попробуйте тот же код на другом устройстве   -  person Khizar Hayat    schedule 19.04.2016
comment
Я использую последнюю версию Android Studio и AVD Manager. И такая же проблема возникает на моем реальном устройстве и в эмуляторе.   -  person lpasztor    schedule 21.04.2016
comment
использование эмулятора устройства не заслуживает доверия   -  person Khizar Hayat    schedule 21.04.2016
comment
Но я также пробовал это на двух разных телефонах. Это что-то с / в коде, но я не могу его найти.   -  person lpasztor    schedule 23.04.2016


Ответы (3)


Здесь ничего удивительного,

Поведение метода onDestroy()

В некоторых ситуациях Система просто убивает хост-процесс активности, не вызывая этот метод. ИЛИ Система может напрямую уничтожить ваше приложение. Если оно попадает в ситуации нехватки памяти, даже ваше приложение находится в onStop (). И еще одна вещь, на которую следует обратить внимание, - метод onStop() также не может быть вызван в ситуациях с нехваткой памяти.

Подробнее см. onDestroy() метод.

person Shree Krishna    schedule 19.04.2016
comment
Я использую последнюю версию Android Studio и AVD Manager. И такая же проблема возникает на моем реальном устройстве и в эмуляторе. И я также быстро написал простое приложение с протоколированием различных жизненных циклов пустого проекта, и там все работало нормально, как и ожидалось. Так что это не имеет отношения к нехватке памяти, это что-то в коде. - person lpasztor; 21.04.2016

Хорошо, когда вы вызываете MainActivity.this.finish (); или LoginActivity.this.finish (); деятельность нарушена. попробуйте не вызывать finish (), если вы не хотите уничтожать необходимую активность

person Konstantin    schedule 19.04.2016
comment
Эти части вызываются напрямую с функциями, и, к сожалению, они не имеют никакого отношения к этой проблеме. - person lpasztor; 21.04.2016

Я обнаружил проблему: в файле mainfest для обоих действий был установлен android: noHistory = "true". Теперь жизненный цикл активности работает нормально.

Однако теперь с экрана входа в систему я могу просто вернуться на главный экран, нажав кнопку «Назад» ... и это не нормально. :)

person lpasztor    schedule 23.04.2016