1. 程式人生 > >Android中ActivityLifecycleCallbacks監聽Activity們的生命週期

Android中ActivityLifecycleCallbacks監聽Activity們的生命週期

如果你還在Activity的宣告周期函式(onCreate、onStart)列印log來看activity的宣告週期,那麼你就out了!

今天樓主叫你用ActivityLifecycleCallbacks來監聽activity們的宣告週期。

接下來上程式碼:

AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.lxxcaroline.applicationtest">

    <application
        android:name="com.example.lxxcaroline.test.MyApplication"
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme">
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            android:name=".SecondActivity"
            android:label="secondActivity">
        </activity>
    </application>

</manifest>

MainActivity.java:
package com.example.lxxcaroline.applicationtest;

import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.util.Log;
import android.view.View;
import android.widget.Button;

public class MainActivity extends ActionBarActivity {
    private static final String TAG="ApplicationTest";
    private Button button;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Log.d(TAG,"MainActivity is created successfully.");
        button=(Button)findViewById(R.id.btn);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent=new Intent(MainActivity.this,SecondActivity.class);
                startActivity(intent);
            }
        });
    }
}

SecondActivity.java:
package com.example.lxxcaroline.applicationtest;

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

/**
 * Created by LxxCaroline on 2015/5/4.
 */
public class SecondActivity extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.layout);
    }
}
activity_main.xml:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin"
    tools:context=".MainActivity">

   <Button
       android:id="@+id/btn"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="button"/>

</RelativeLayout>

layout.xml:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin"
    tools:context=".MainActivity">

    <TextView
        android:text="@string/hello_world"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

</RelativeLayout>

MyApplication.java:
package com.example.lxxcaroline.test;

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

import com.example.lxxcaroline.applicationtest.MainActivity;
import com.example.lxxcaroline.applicationtest.SecondActivity;

/**
 * Created by LxxCaroline on 2015/5/3.
 */
public class MyApplication extends Application {
    private static final String TAG = "MyApplication";
    //宣告一個監聽Activity們生命週期的介面
    private ActivityLifecycleCallbacks activityLifecycleCallbacks = new ActivityLifecycleCallbacks() {
        /**
         * application下的每個Activity宣告週期改變時,都會觸發以下的函式。
         */
        @Override
        public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
            //如何區別引數中activity代表你寫的哪個activity。
            if (activity.getClass() == MainActivity.class)
                Log.d(TAG, "MainActivityCreated.");
            else if(activity.getClass()== SecondActivity.class)
                Log.d(TAG, "SecondActivityCreated.");
        }

        @Override
        public void onActivityStarted(Activity activity) {
            Log.d(TAG, "onActivityStarted.");
        }

        @Override
        public void onActivityResumed(Activity activity) {
            Log.d(TAG, "onActivityResumed.");
        }

        @Override
        public void onActivityPaused(Activity activity) {
            Log.d(TAG, "onActivityPaused.");
        }

        @Override
        public void onActivityStopped(Activity activity) {
            Log.d(TAG, "onActivityStopped.");
        }

        @Override
        public void onActivitySaveInstanceState(Activity activity, Bundle outState) {
        }

        @Override
        public void onActivityDestroyed(Activity activity) {
            Log.d(TAG, "onActivityDestroyed.");
        }
    };

    /**
     * onCreate是一個回撥介面,android系統會在應用程式啟動的時候,在任何應用程式元件(activity、服務、
     * 廣播接收器和內容提供者)被建立之前呼叫這個介面。
     * 需要注意的是,這個方法的執行效率會直接影響到啟動Activity等的效能,因此此方法應儘快完成。
     * 最後在該方法中,一定要記得呼叫super.onCreate(),否則應用程式將會報錯。
     */
    @Override
    public void onCreate() {
        super.onCreate();
        //註冊自己的Activity的生命週期回撥介面。
        registerActivityLifecycleCallbacks(activityLifecycleCallbacks);
    }

    @Override
    public void onTerminate() {
        //登出這個介面。
        unregisterActivityLifecycleCallbacks(activityLifecycleCallbacks);
        super.onTerminate();
    }
}

跑起來的log,步驟:進入程式,點選首頁的按鈕,進入第二個頁面,然後依次返回到桌面上,log如下:
05-04 10:28:03.489  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ MainActivityCreated.
05-04 10:28:03.639  24885-24885/com.example.lxxcaroline.applicationtest D/ApplicationTest﹕ MainActivity is created successfully.
05-04 10:28:03.639  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityStarted.
05-04 10:28:03.649  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityResumed.
05-04 10:28:33.361  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityPaused.
05-04 10:28:33.391  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ SecondActivityCreated.
05-04 10:28:33.411  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityStarted.
05-04 10:28:33.411  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityResumed.
05-04 10:28:33.781  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityStopped.
05-04 10:28:36.835  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityPaused.
05-04 10:28:36.875  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityStarted.
05-04 10:28:36.875  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityResumed.
05-04 10:28:37.205  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityStopped.
05-04 10:28:37.205  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityDestroyed.
05-04 10:28:38.627  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityPaused.
05-04 10:28:39.177  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityStopped.
05-04 10:28:39.177  24885-24885/com.example.lxxcaroline.applicationtest D/MyApplication﹕ onActivityDestroyed.