监听Android所有Activity的生命周期

最近想监听App从后台切换到前台的监听,不巧发现了这个玩意ActivityLifecycleCallbacks
看名字就是一个会被回调的方法。
1 继承Application,并指定
2 实现这个interface

 
private ActivityLifecycleCallbacks mLifecycleCallback = new ActivityLifecycleCallbacks() {
@Override
public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
LogUtil.i(“onCreate:”+activity.getClass().getSimpleName());
}

    @Override
    public void onActivityStarted(Activity activity) {
        LogUtil.i("onStart:"+activity.getClass().getSimpleName());

    }

    @Override
    public void onActivityResumed(Activity activity) {
        LogUtil.i("onResumed:"+activity.getClass().getSimpleName());

    }

    @Override
    public void onActivityPaused(Activity activity) {
        LogUtil.i("onPaused:"+activity.getClass().getSimpleName());

    }

    @Override
    public void onActivityStopped(Activity activity) {
        LogUtil.i("onStop:"+activity.getClass().getSimpleName());

    }

    @Override
    public void onActivitySaveInstanceState(Activity activity, Bundle outState) {
        LogUtil.i("onSaveInstanceState:"+activity.getClass().getSimpleName());

    }

    @Override
    public void onActivityDestroyed(Activity activity) {
        LogUtil.i("onDestroyed:"+activity.getClass().getSimpleName());

    }
};

</pre>

3 在Application中的onCreate方法,进行注册

 
public class MyApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
// Create an InitializerBuilder
Stetho.InitializerBuilder initializerBuilder =
Stetho.newInitializerBuilder(this);

    // Enable Chrome DevTools
    initializerBuilder.enableWebKitInspector(
            Stetho.defaultInspectorModulesProvider(this)
    );

    // Enable command line interface
    initializerBuilder.enableDumpapp(
            Stetho.defaultDumperPluginsProvider(this)
    );

    // Use the InitializerBuilder to generate an Initializer
    Stetho.Initializer initializer = initializerBuilder.build();

    // Initialize Stetho with the Initializer
    Stetho.initialize(initializer);
    //前面是我继承的Stetho调试工具,大家可以忽略 
    //前面的LogUtil也是Stetho的,,,so 大家可以替换为Log
    registerActivityLifecycleCallbacks(mLifecycleCallback);

}
</pre>

4 运行时log

 
10-14 09:44:29.760 7491-7506/? I/stetho: Listening on @stetho_aze_zer0.azezer0utils_devtools_remote
10-14 09:44:29.808 7491-7491/? I/stetho: onCreate:MainActivity
10-14 09:44:30.357 7491-7491/? I/stetho: onStart:MainActivity
10-14 09:44:30.357 7491-7491/? I/stetho: onResumed:MainActivity
10-14 09:45:05.139 7491-7491/aze_zer0.azezer0utils I/stetho: onPaused:MainActivity
10-14 09:45:05.165 7491-7491/aze_zer0.azezer0utils I/stetho: onCreate:MainActivity2
10-14 09:45:05.193 7491-7491/aze_zer0.azezer0utils I/stetho: onStart:MainActivity2
10-14 09:45:05.194 7491-7491/aze_zer0.azezer0utils I/stetho: onResumed:MainActivity2
10-14 09:45:05.838 7491-7491/aze_zer0.azezer0utils I/stetho: onSaveInstanceState:MainActivity
10-14 09:45:05.838 7491-7491/aze_zer0.azezer0utils I/stetho: onStop:MainActivity
10-14 09:45:25.157 7491-7491/aze_zer0.azezer0utils I/stetho: onPaused:MainActivity2
10-14 09:45:25.173 7491-7491/aze_zer0.azezer0utils I/stetho: onSaveInstanceState:MainActivity2
10-14 09:45:25.173 7491-7491/aze_zer0.azezer0utils I/stetho: onStop:MainActivity2
10-14 09:45:53.287 7491-7491/aze_zer0.azezer0utils I/stetho: onStart:MainActivity2
10-14 09:45:53.287 7491-7491/aze_zer0.azezer0utils I/stetho: onResumed:MainActivity2
10-14 09:45:57.884 7491-7491/aze_zer0.azezer0utils I/stetho: onPaused:MainActivity2
10-14 09:45:57.892 7491-7491/aze_zer0.azezer0utils I/stetho: onStart:MainActivity
10-14 09:45:57.892 7491-7491/aze_zer0.azezer0utils I/stetho: onResumed:MainActivity
10-14 09:45:58.275 7491-7491/aze_zer0.azezer0utils I/stetho: onStop:MainActivity2
10-14 09:45:58.276 7491-7491/aze_zer0.azezer0utils I/stetho: onDestroyed:MainActivity2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值