2011年5月10日火曜日

Activityのライフサイクルの確認 - Confirming Activity lifecycle -

このエントリーをはてなブックマークに追加
アクティビティの状態遷移とライフサイクルメソッドを確認しました。

We confirmed activity state transition and lifecycle methods.



アクティビティのライフサイクルは、Activityに関するリファレンスに掲載されています。
http://developer.android.com/intl/ja/reference/android/app/Activity.html


状態遷移の確認
状態遷移と、その時に呼び出されるメソッドは次の通りでした。
(1) 起動
Activityを起動して、フォアグラウンドになるまで。
onCreate → onStart → onResume

(2) 画面表示の変化
onResume後の状態から、端末を縦から横へ傾けたとき。
(onResume) → onPause → onStop → onDestroy → onCreate → onStart → onResume

(3) ホームボタンの押下
onResume後の状態から、ホームボタンを押したとき。
(onResume) → onPause → onStop

(4) アプリ再開
(3)の最後の状態から、アプリを再開したとき。
(onStop) → onRestart → onStart → onResume

(5) アプリ終了
onResume後の状態から、アプリば終了するまで。
(onResume) → onPause → onStop → onDestroy


プログラム
package sgl.test.activity;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;

public class ActivityTest extends Activity {
     private final String TAG = "ActivityTest";

     @Override
     public void onCreate(Bundle savedInstanceState) {
          super.onCreate(savedInstanceState);
          Log.i(TAG, "onCreate");
     }

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

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

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

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

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

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


実行結果
(1)から(5)までを順番に行って、そのログを見てみました。それらを実行開始時間は次の通りです。
(1) 21:13:44.888
(2) 21:13:53.168
(3) 21:13:57.078
(4) 21:14:01.848
(5) 21:14:11.998



端末を傾けたときに一度Activityが消滅してしまうので、そこに注意が必要だと感じます。

0 件のコメント:

コメントを投稿