поток onCreate продолжается после finish()

Я хочу завершить деятельность изнутри метода onCreate. Когда я вызываю finish(), onDestroy() вызывается не сразу, код продолжает течь мимо finish(). onDestroy() вызывается только после закрывающей скобки onCreate().

Согласно описанию onCreate() на сайте developer.android.com/reference.

Вы можете вызвать finish() из этой функции, в этом случае onDestroy() будет немедленно вызвана без какого-либо из оставшихся частей жизненного цикла активности (onStart(), onResume(), onPause() и т.д.).

Причина, по которой я спрашиваю: Я хотел бы проверить данные из Bundle, переданные в onCreate(). Конечно, я контролирую то, что передается в onCreate(), но я все же думаю, что это должно быть проверено в точке доставки.

Мой код содержит класс A, который запускает Activity B. Я считаю, что последние два тега "вне пункта if" не должны вызываться, потому что метод finish в утверждении if должен был уничтожить активность. Оговорка if здесь ни при чем, потому что строка тега после второго вызова finish() также читается.

Мой код:

Класс A

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    // goToBButton: when pressed sends message to class B.    
    Button goToBButton = (Button)this.findViewById(R.id.go_to__b_btn);
    goToBButton.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick (View v) {      
            Log.i(TAG,"A Class: goToBButton, onClick");
            Intent i = new Intent(A.this, B.class);
            startActivityForResult(i,REQ_TO_B);
        }       
    });                
} // end onCreate

Мой код КлассB

    public class B extends Activity{

private static final String TAG = "tag";

@Override
   public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.layoutb);

  // set as true, should always print Tag: one line before first finish"
  if (true)  {

    Log.i(TAG,"B Class: one line before 1st finish");
    finish();
  }

  // shouldn't get here after first finish
  Log.i(TAG,"B Class: outside of if clause, before second finish");
  finish();
  // shouldn't get here after second finish
  Log.i(TAG,"B Class: outside of if clause, after finish");                  
   } // end onCreate


@Override
public void onStart () {
    super.onStart();
    Log.i(TAG,"B Class: onStart");
}

@Override
public void onRestart() {
    super.onRestart();
    Log.i(TAG,"B Class: onRestart");
}

@Override
public void onResume () {
    super.onResume();
    Log.i(TAG,"B Class: onResume");
}

@Override
public void onPause () {
    super.onPause();
    Log.i(TAG,"B Class: onPause");
}

@Override
public void onStop () {
    super.onStop();
    Log.i(TAG,"B Class: onStop");
}

@Override
public void onDestroy () {
    super.onDestroy();
    Log.i(TAG,"B Class: onDestroy");
}

 } // end B Class

Вот результаты моих тегов:

11-26 15:53:40.456: INFO/tag(699): A Class: goToBButton, onClick

11-26 15:53:40.636: INFO/tag(699): A Class: onPause

11-26 15:53:40.865: INFO/tag(699): B Class: одна линия перед 1-м финишем

11-26 15:53:40.896: INFO/tag(699): B Class: вне пункта if, перед вторым финишем

11-26 15:53:40.917: INFO/tag(699): B Класс: вне пункта if, после финиша

11-26 15:53:41.035: INFO/tag(699): A Класс: onResume

11-26 15:53:41.165: INFO/tag(699): B Class: onDestroy

74
задан Jeffrey Bosboom 16 March 2015 в 04:37
поделиться