Android Life Cycle of Activity
We can control and manage the resource through the life cycle methods of activity.There are 7 life cycle methods of android.app.Activity class.
They are as follows:
Method | Description | ||||||
---|---|---|---|---|---|---|---|
onCreate | called when activity is first created. | ||||||
onStart | called when activity is becoming visible to the user. | ||||||
onResume | called when activity will start interacting with the user. | ||||||
onPause | called when activity is not visible to the user. | ||||||
onStop | called when activity is no longer visible to the user. | ||||||
onRestart | called after your activity is stopped, prior to start. | ||||||
onDestroy | called before the activity is destroyed. |
data:image/s3,"s3://crabby-images/aee2b/aee2b3b987c7d46c2446aa9952d99c46b3fe84a9" alt="android activity lifecycle"
Android Activity Life Cycle Example
It provides the details about the invocation of life cycle methods of activity. In this example, we are displaying the content on the logcat.
File: MainActivity.java
package com.example.activitylifecycle;
import android.os.Bundle;
import android.app.Activity;
import android.util.Log;
import android.view.Menu;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.d("lifecycle","onCreate invoked");
}
@Override
protected void onStart() {
super.onStart();
Log.d("lifecycle","onStart invoked");
}
@Override
protected void onResume() {
super.onResume();
Log.d("lifecycle","onResume invoked");
}
@Override
protected void onPause() {
super.onPause();
Log.d("lifecycle","onPause invoked");
}
@Override
protected void onStop() {
super.onStop();
Log.d("lifecycle","onStop invoked");
}
@Override
protected void onRestart() {
super.onRestart();
Log.d("lifecycle","onRestart invoked");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.d("lifecycle","onDestroy invoked");
}
}
import android.os.Bundle;
import android.app.Activity;
import android.util.Log;
import android.view.Menu;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.d("lifecycle","onCreate invoked");
}
@Override
protected void onStart() {
super.onStart();
Log.d("lifecycle","onStart invoked");
}
@Override
protected void onResume() {
super.onResume();
Log.d("lifecycle","onResume invoked");
}
@Override
protected void onPause() {
super.onPause();
Log.d("lifecycle","onPause invoked");
}
@Override
protected void onStop() {
super.onStop();
Log.d("lifecycle","onStop invoked");
}
@Override
protected void onRestart() {
super.onRestart();
Log.d("lifecycle","onRestart invoked");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.d("lifecycle","onDestroy invoked");
}
}
Output:
You will not see any output on the emulator or device. You need to open logcat.data:image/s3,"s3://crabby-images/8b555/8b5559406e406236cec971e52bc461f1b7422917" alt="android activity life cycle example output 1"
Now see on the logcat: onCreate, onStart and onResume methods are invoked.
data:image/s3,"s3://crabby-images/0f200/0f20093247dbaf47f28ebf85eb2fb0a34b210c81" alt="android activity life cycle example output 2"
Now click on the HOME Button. You will see onPause method is invoked.
data:image/s3,"s3://crabby-images/f9a09/f9a093b738583035f33499426c698b7e84122700" alt="android activity life cycle example output 3"
After a while, you will see onStop method is invoked.
data:image/s3,"s3://crabby-images/21805/21805c69fb5e675399c405402dd04692207f4ed7" alt="android activity life cycle example output 4"
Now see on the emulator. It is on the home. Now click on the center button to launch the app again.
data:image/s3,"s3://crabby-images/1b70d/1b70dc0d0cad997f4b79e12b95a20389523f264e" alt="android activity life cycle example output 5"
Now click on the lifecycleactivity icon.
data:image/s3,"s3://crabby-images/4ccb0/4ccb02c710067639e188bbea305a98051f69fe1e" alt="android activity life cycle example output 6"
Now see on the logcat: onRestart, onStart and onResume methods are invoked.
data:image/s3,"s3://crabby-images/c7a8d/c7a8d49c94501cc59f8636c418d147091ddc0a9f" alt="android activity life cycle example output 7"
If you see the emulator, application is started again.
data:image/s3,"s3://crabby-images/5651e/5651eaeae6b84e77d6a136b3567d00b963327c87" alt="android activity life cycle example output 8"
data:image/s3,"s3://crabby-images/a906c/a906c5a70f9bf36a4a579ef3cca1141c34407857" alt="android activity life cycle example output 9"
After a while, you will see onStop and onDestroy methods are invoked.
data:image/s3,"s3://crabby-images/02af2/02af2b64e3a4d6cba276839893798e01a55734aa" alt="android activity life cycle example output 10"