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