欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android判斷App前臺(tái)運(yùn)行還是后臺(tái)運(yùn)行(運(yùn)行狀態(tài))

 更新時(shí)間:2016年04月05日 11:50:50   作者:一葉飄舟  
這篇文章主要介紹了Android判斷App前臺(tái)運(yùn)行還是后臺(tái)運(yùn)行的相關(guān)資料,需要的朋友可以參考下

本文通過圖文并茂的方式給大家介紹android判斷app狀態(tài)的相關(guān)內(nèi)容,具體詳情如下所示:

要了解這塊,首先需要明白一些概念,app,process,task

1.process就是進(jìn)程,是linux的概念。

2.一般一個(gè)app擁有一個(gè)uid,運(yùn)行在一個(gè)進(jìn)程里,如果app中給service等定義不同的uid,那Service就運(yùn)行在另外一個(gè)進(jìn)程里,也就是說uid就相當(dāng)于進(jìn)程的id一樣,一個(gè)uid就代表一個(gè)進(jìn)程;也可以幾個(gè)app定義一個(gè)uid,那他們就運(yùn)行在一個(gè)進(jìn)程里了。

3.task是android系統(tǒng)的一個(gè)activity的棧,包含多個(gè)app的activity,通過ActivityManager可以獲取棧中的activity信息,從而判斷activity對應(yīng)應(yīng)用的狀態(tài)。

3.1可以做的事情包括:

ActivityManagermActivityManager = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);
PackageManagermPackageManager = context.getPackageManager();

①getRecentTasks() 獲取最近打開的task,手機(jī)查看最近打開的應(yīng)用可以用這個(gè)實(shí)現(xiàn)。

②getRunningAppProcess() 獲取app運(yùn)行中的process。

List list = mActivityManager.getRunningAppProcesses();
StringBuilder apps = new StringBuilder();
for (RunningAppProcessInfo info : list) {
apps.append(info.processName + "\n" + info.importance);
}
System.out.println(apps.toString());

list是系統(tǒng)當(dāng)前運(yùn)行進(jìn)程的集合,importance屬性==100 表示這個(gè)進(jìn)程在前臺(tái),其他數(shù)字表示在后臺(tái),所以通過importance和processName判斷應(yīng)用是否在前臺(tái)

我做測試的時(shí)候,方法返回的list中只有這個(gè)應(yīng)用的進(jìn)程,前臺(tái)是狀態(tài)是100,后臺(tái)時(shí)狀態(tài)是400,

這是因?yàn)槲业氖謾C(jī)是5.0以上的,從api21開始這個(gè)方法只能返回自身應(yīng)用的進(jìn)程信息,如果應(yīng)用中有Service并且定義了process屬性,那么就會(huì)返回兩個(gè)進(jìn)程,app進(jìn)程仍是100,Service是其他值。5.0以下可以返回所有,另外有個(gè)方法5.0以上可以返回所有,5.0以下不行,后面說。

*另外:當(dāng)某個(gè)app的Service設(shè)置為粘性時(shí),Service所在的app就會(huì)被認(rèn)為是在前臺(tái),app進(jìn)程的importance一直是100,這個(gè)時(shí)候就不能通過這個(gè)方法判斷是否在前臺(tái)了。

總結(jié):5.0以上只能判斷自身應(yīng)用是否在前臺(tái),當(dāng)有app的Service被設(shè)置為粘性時(shí),就不能用了 。

If(importance == 100) 中100在runningprocessinfo下的常量IMPORTANCE_FOREGROUND

所以這里要寫成 if(info.importance == RunningProcessInfo.IMPORTANCE_FOREGROUND)

③getRunningServices()獲取系統(tǒng)運(yùn)行中的后臺(tái)service。

④getRunningTask()獲取系統(tǒng)運(yùn)行中的任務(wù)。

上面說了activity的task棧,棧頂activity所在app就是前臺(tái)的app,所有拿到棧頂activity的信息獲取他的包名,對比應(yīng)用的包名來判斷應(yīng)用是不是在前臺(tái),5.0以前可以判斷是哪個(gè)應(yīng)用在前臺(tái),5.0以后只會(huì)返回自身和部分不重要task,不能再判斷其他應(yīng)用是否在前臺(tái),只能判斷自己了。

ActivityManager am = (ActivityManager) context
.getSystemService(Context.ACTIVITY_SERVICE);
List tasks = am.getRunningTasks(1);
if (!tasks.isEmpty()) {
ComponentName topActivity = tasks.get(0).topActivity;
if (topActivity.getPackageName().equals(context.getPackageName())) {
“前臺(tái)”
}
}

“后臺(tái)”

4.ActivityLifecycleCallbacks

以前做過所有的activity都集成baseactivity,重寫onCreate方法,onStop方法,定義一個(gè)變量count統(tǒng)計(jì)打開的activity數(shù),onCreate時(shí) count++,onStop時(shí)count--,當(dāng)count == 0 時(shí),應(yīng)用就在后臺(tái)了?,F(xiàn)在,從api14開始,api提供了一個(gè)所有activity生命周期的回調(diào),就是ActivityLifecycleCallbacks,每個(gè)activity的生命周期都會(huì)觸發(fā),通過registerActivityLifecycleCallbacks注冊這個(gè)回調(diào)。

其實(shí)和重寫baseactivity的onCreate和onStop一樣的,在回調(diào)的onCreate中count++,onStop中count--,在onStop中增加個(gè)判斷,if(count == 0){“我在后臺(tái)了”},為什么在onStop中呢?不論是back返回還是home退出,還是其他手段退出,activity總會(huì)回調(diào)onStop的。

也可以在onStop中直接調(diào)用getRunningAppProcess或者getRunningTask判斷應(yīng)用是不是跑后臺(tái)去了,這個(gè)時(shí)候可以做一些事情。然后從后臺(tái)回到前臺(tái)調(diào)用onCreate,又可以做一些事情。

我做過的這個(gè)是在每次應(yīng)用跑到前臺(tái)時(shí)就檢測是不是有新版本更新。在自定義application的onCreate中注冊這個(gè)回調(diào)。

5.UsageStatsManager ,這個(gè)就是上面說的5.0以后才有效的方法.使用需要加入權(quán)限

<uses-permission android:name="android.permission.PACKAGE_USAGE_STATS" tools:ignore="ProtectedPermissions" xmlns:tools="http://schemas.android.com/tools"></uses-permission>

手機(jī)-設(shè)置-安全-高級(jí),在有權(quán)查看使用情況的應(yīng)用中,選中自己應(yīng)用。

6.通過Android自帶的無障礙功能,

http://effmx.com/articles/tong-guo-android-fu-zhu-gong-neng-accessibility-service-jian-ce-ren-yi-qian-tai-jie-mian/

7.讀取Linux內(nèi)核保護(hù)在/proc目錄下的process進(jìn)程信息,GitHub地址https://github.com/jaredrummler/AndroidProcesses

不需要權(quán)限,可以判斷任意應(yīng)用是否在前臺(tái),但是檢索文件夾需要時(shí)間。

用法

獲取一系列正在運(yùn)行的App的進(jìn)程

List processes = ProcessManager.getRunningAppProcesses();</androidappprocess>

獲取任一正在運(yùn)行的App進(jìn)程的詳細(xì)信息

AndroidAppProcess process = processes.get(location);
String processName = process.name;
Stat stat = process.stat();
int pid = stat.getPid();
int parentProcessId = stat.ppid();
long startTime = stat.stime();
int policy = stat.policy();
char state = stat.state();
Statm statm = process.statm();
long totalSizeOfProcess = statm.getSize();
long residentSetSize = statm.getResidentSetSize();
PackageInfo packageInfo = process.getPackageInfo(context, 0);
String appName = packageInfo.applicationInfo.loadLabel(pm).toString();

判斷是否在前臺(tái)

if (ProcessManager.isMyProcessInTheForeground()) {
// do stuff
}

獲取一系列正在運(yùn)行的App進(jìn)程的詳細(xì)信息

List processes = ProcessManager.getRunningAppProcessInfo(ctx);</activitymanager.runningappprocessinfo>

以上內(nèi)容是針對android判斷app 狀態(tài),希望對大家有所幫助!

相關(guān)文章

最新評(píng)論