判断前台 Activity 是否属于本进程

简介: 一种判断前台 Activity 是否属于本进程的方法。

本文记录的是一种判断当前激活的 Activity 是否属于本进程的方法。

约定:文中表述说一个 Activity 处于激活状态是指它是屏幕上当前展示的 Activity,且没有被 Dialog 覆盖。

原理

Activity 的生命周期由 Android 系统维护,所以使用一个 Activity 的生命周期方法 onResumeonPause 来记录它的激活状态是可靠的。

同理,因为前台 Activity 只有一个,所以判断前台 Activity 是否属于本进程只需要判断本进程是否有 Activity 处于激活状态即可。

实现

顺着这个思路,直接想到的方案就是去给代码里所有的 Activity 实现一个共同基类,然后在基类里的 onResumeonPause 方法去更新一个全局计数器了。

这固然可行,但遇到有些不能继承共同基类的情况,比如继承自 ListActivity 和 ExpandableListActivity 等 Activity 的子类的,就得重复去在具体 Activity 里的对应方法里添加代码了,一旦有一个 Activity 忘了添加,这个机制就失效了,所以并不优雅。

幸好 Android 在 API Level 14 的时候新加入了 android.app.Application.ActivityLifecycleCallbacks 接口,它会在 Activity 生命周期事件发生时产生回调:

public interface ActivityLifecycleCallbacks {
   
    void onActivityCreated(Activity activity, Bundle savedInstanceState);
    void onActivityStarted(Activity activity);
    void onActivityResumed(Activity activity);
    void onActivityPaused(Activity activity);
    void onActivityStopped(Activity activity);
    void onActivitySaveInstanceState(Activity activity, Bundle outState);
    void onActivityDestroyed(Activity activity);
}

这真是救星。

那么优雅的实现方案:

public class MyApplication extends Application {
   
    private static boolean hasActivityActivate = false;

    @Override
    public void onCreate() {
   
        super.onCreate();
        registerActivityLifecycleCallbacks(new ActivityLifecycleCallbacks() {
   
            @Override
            public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
   

            }

            @Override
            public void onActivityStarted(Activity activity) {
   

            }

            @Override
            public void onActivityResumed(Activity activity) {
   
                hasActivityActivate = true;
            }

            @Override
            public void onActivityPaused(Activity activity) {
   
                hasActivityActivate = false;
            }

            @Override
            public void onActivityStopped(Activity activity) {
   

            }

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

            }

            @Override
            public void onActivityDestroyed(Activity activity) {
   

            }
        });
    }

    public static boolean hasActivityActivate() {
   
        return hasActivityActivate;
    }
}

然后在需要的时候调用 MyApplication.hasActivityActivate() 就行了。

当然别忘了在 AndroidManifest.xml 里声明指定你的 Application 类名:

...
<application
    android:name=".MyApplication"
    ....

后话

本文记录的只是判断当前进程是否有 Activity 处于激活状态的方法,判断当前应用、其它应用的前后台情况有多种方法,它们的优缺点、适用场景在以下 GitHub 仓库有详细列举,有需求的同学可以参考:

https://github.com/wenmingvs/AndroidProcess

参考

目录
相关文章
|
8月前
|
Linux Shell
Linux 进程的前台/后台切换
当你用shell启动一个程序时,往往他是在前台工作的。程序会一直占用终端命令行,例如你在前台解压的时候必须等着,期间干不了别的事(除非另开一个终端)。 例如经常用连接到远程服务器执行脚本的时候,如果本地网络中断后,这个时候前台进程就结束了,比较的懊恼,必须重新执行。
150 6
|
5月前
|
Android开发 开发者 Kotlin
Android 多进程情况下判断应用是否处于前台或者后台
本文介绍在多进程环境下判断Android应用前后台状态的方法。通过`ActivityManager`和服务信息`RunningAppProcessInfo`可有效检测应用状态,优化资源使用。提供Kotlin代码示例,帮助开发者轻松集成。
328 8
|
Java API Android开发
【Android 应用开发】Android 杀进程总结 ( 杀后台进程 | 杀前台进程 | 杀其它进程 )
【Android 应用开发】Android 杀进程总结 ( 杀后台进程 | 杀前台进程 | 杀其它进程 )
1463 0
|
前端开发 Java Linux
内存泄露,OOM,ANR ,Devik 进程,Framework原理,Activity 生成一个 view,Android 中的动画,SurfaceView和V
内存泄露,OOM,ANR ,Devik 进程,Framework原理,Activity 生成一个 view,Android 中的动画,SurfaceView和V
252 0
|
Android开发
【Android 进程保活】提升进程优先级 ( 使用前台 Service 提高应用进程优先级 | 效果展示 | 源码资源 )(二)
【Android 进程保活】提升进程优先级 ( 使用前台 Service 提高应用进程优先级 | 效果展示 | 源码资源 )(二)
322 0
【Android 进程保活】提升进程优先级 ( 使用前台 Service 提高应用进程优先级 | 效果展示 | 源码资源 )(二)
|
Android开发
【错误记录】前台进程报错 ( Bad notification for startForeground invalid channel for service notification )
【错误记录】前台进程报错 ( Bad notification for startForeground invalid channel for service notification )
1447 0
【错误记录】前台进程报错 ( Bad notification for startForeground invalid channel for service notification )
|
Android开发
【错误记录】前台进程报错 ( Permission Denial: startForeground requires android.permission.FOREGROUND_SERVICE )
【错误记录】前台进程报错 ( Permission Denial: startForeground requires android.permission.FOREGROUND_SERVICE )
623 0
【错误记录】前台进程报错 ( Permission Denial: startForeground requires android.permission.FOREGROUND_SERVICE )
|
Java Android开发
【Android 插件化】Hook 插件化框架 ( 从 Hook 应用角度分析 Activity 启动流程 二 | AMS 进程相关源码 | 主进程相关源码 )
【Android 插件化】Hook 插件化框架 ( 从 Hook 应用角度分析 Activity 启动流程 二 | AMS 进程相关源码 | 主进程相关源码 )
115 0
|
算法 Java Android开发
【Android 插件化】Hook 插件化框架 ( 从 Hook 应用角度分析 Activity 启动流程 一 | Activity 进程相关源码 )
【Android 插件化】Hook 插件化框架 ( 从 Hook 应用角度分析 Activity 启动流程 一 | Activity 进程相关源码 )
203 0
|
Java Android开发
【Android 插件化】Hook 插件化框架 ( 从 Hook 应用角度分析 Activity 启动流程 二 | AMS 进程相关源码 | 主进程相关源码 )(三)
【Android 插件化】Hook 插件化框架 ( 从 Hook 应用角度分析 Activity 启动流程 二 | AMS 进程相关源码 | 主进程相关源码 )(三)
160 0