Android判断前后台的方法分析(二)

( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)🥬( ´◔︎ ‸◔︎)

判断前后台的方法往往五花八门,这次让我们再一起看一种Android中常用的前后台切换的方法 ActivityLifecycleCallbacks

ActivityLifecycleCallbacks是一个接口,它可以用来监听Activity的生命周期事件。当应用程序中的Activity经历生命周期事件时,系统会回调这个接口中的相应方法,从而允许开发者在Activity生命周期不同阶段插入自己的逻辑。

详细代码可以看ActivityonCreate方法dispatchActivityCreated,(其实看其他生命周期回调也是一样的)

less 复制代码
protected void onCreate(@Nullable Bundle savedInstanceState) {
    ...不重要的代码省略了...
    dispatchActivityCreated(savedInstanceState);
    ...不重要的代码省略了...
}

再来往里看dispatchActivityCreated到底做了什么

less 复制代码
private void dispatchActivityCreated(@Nullable Bundle savedInstanceState) {
    getApplication().dispatchActivityCreated(this, savedInstanceState);
    Object[] callbacks = collectActivityLifecycleCallbacks();
    if (callbacks != null) {
        for (int i = 0; i < callbacks.length; i++) {
            ((Application.ActivityLifecycleCallbacks) callbacks[i]).onActivityCreated(this,
                    savedInstanceState);
        }
    }
}
ini 复制代码
private Object[] collectActivityLifecycleCallbacks() {
    Object[] callbacks = null;
    synchronized (mActivityLifecycleCallbacks) {
        if (mActivityLifecycleCallbacks.size() > 0) {
            callbacks = mActivityLifecycleCallbacks.toArray();
        }
    }
    return callbacks;
}

这里的mActivityLifecycleCallbacks就是我们注册进来的生命周期的监听回调

arduino 复制代码
application.registerActivityLifecycleCallbacks(new Application.ActivityLifecycleCallbacks()

因此可以看出来,ActivityLifecycleCallbacks的核心逻辑是在应用程序的每一个Activity的生命周期内提供了一个挂钩(hook),允许开发者在特定的时机执行特定的操作,比如在Activity启动时记录日志、在Activity销毁时释放资源等。通过实现ActivityLifecycleCallbacks接口,开发者可以监听应用程序中所有Activity的生命周期事件,从而更好地管理和优化应用程序的性能和行为。

讲了这么多,来点干货,如果想封装一个Activity的状态管理类,并使其支持判断前后台,那么如下:

typescript 复制代码
public final class ActivityStack {

    private static final LinkedList<Activity> sActivityStack = new LinkedList<>();

    private static Boolean isInBackground = true;

    private static WeakHashMap<Activity, String> sStartActivityWeakRef = new WeakHashMap<>();

    private static final CopyOnWriteArrayList<IActivityStackListener> sActivityStackListeners = new CopyOnWriteArrayList<>();


    public static void init(Application application) {
        application.registerActivityLifecycleCallbacks(new Application.ActivityLifecycleCallbacks() {
            @Override
            public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
                synchronized (ActivityStack.class) {
                    sActivityStack.remove(activity);
                    sActivityStack.add(activity);
                    notifyActivityStackListener(activity, ActivityStackStatus.CREATE);
                }
            }

            @Override
            public void onActivityStarted(Activity activity) {
                synchronized (ActivityStack.class) {
                    sStartActivityWeakRef.put(activity, activity.getClass().getName());
                    notifyActivityStackListener(activity, ActivityStackStatus.START);
                }
            }

            @Override
            public void onActivityResumed(Activity activity) {
                synchronized (ActivityStack.class) {
                    if (isInBackground) {
                        isInBackground = false;
                    }
                    notifyActivityStackListener(activity, ActivityStackStatus.RESUME);
                }
            }

            @Override
            public void onActivityPaused(Activity activity) {
            }

            @Override
            public void onActivityStopped(Activity activity) {
                synchronized (ActivityStack.class) {
                    sStartActivityWeakRef.remove(activity);
                    if (!isInBackground && sStartActivityWeakRef.isEmpty()) {
                        isInBackground = true;
                    }
                    notifyActivityStackListener(activity, ActivityStackStatus.STOP);
                }
            }

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

            }

            @Override
            public void onActivityDestroyed(Activity activity) {
                sActivityStack.remove(activity);
                notifyActivityStackListener(activity, ActivityStackStatus.DESTROY);
            }
        });
    }

    public static synchronized Boolean getIsInBackground() {
        return isInBackground;
    }

    public static synchronized void addActivityStackListener(IActivityStackListener listener) {
        sActivityStackListeners.add(listener);
    }

    public static synchronized void removeActivityStackListener(IActivityStackListener listener) {
        sActivityStackListeners.remove(listener);
    }

    public static synchronized void notifyActivityStackListener(Activity activity, ActivityStackStatus stackStatus) {
        for (IActivityStackListener listener : sActivityStackListeners) {
            listener.onActivityStackChanged(stackStatus);
        }
    }
}
相关推荐
ANnianStriver8 分钟前
PetLumina-AI 驱动的宠物生活管理平台
java·生活·vue3·springboot·ai编程·宠物·全栈开发
好家伙VCC12 分钟前
Delta Lake + Flink 实现近实时数据湖 Schema 演化
java·大数据·flink
吴梓穆14 分钟前
Python 基础语法2 if 运算符 循环
android·开发语言·python
hoho_1214 分钟前
如何替换jar包中依赖的其他jar
java·pycharm·jar
流星白龙15 分钟前
【MySQL高阶】27.事务(2)-锁
android·mysql·adb
码语智行15 分钟前
接口请求处理流程
java
布朗克16816 分钟前
23 泛型——类型安全的参数化编程
java·泛型
我命由我1234518 分钟前
Kotlin 开发 - Kotlin 反引号转义关键字
android·java·开发语言·java-ee·kotlin·android jetpack·android runtime
艾利克斯冰19 分钟前
Java设计模式-工厂方法模式
java
中草药z21 分钟前
【RAG】工程化实战:全链路原理复盘 + 方案选型 + 实战高阶玩法
java·深度学习·机器学习·阿里云·rag·springai