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 件のコメント:
コメントを投稿