Android中获取正在运行的应用程序 您所在的位置:网站首页 检索正在运行应用权限恶心 Android中获取正在运行的应用程序

Android中获取正在运行的应用程序

2024-07-15 14:38| 来源: 网络整理| 查看: 265

 

                                                                                                              转载请注明出处:http://blog.csdn.net/qinjuning

 

          

             

                 今天继续讲解关于ActivityManager的使用,通过前面一节的学习,我们学会了如何利用ActivityManager获取系统里

      正在运行的进程。本文要讲解的知识点是利用这些进程信息获取系统里正在运行的应用程序以及每个进程里运行的应用程序。

     用到的知识点也包括PackageManager的使用,读者阅读在我之前写的blog《PackageManager的使用》

           

              每一个应用程序都会运行在它独立的进程里,但是为了节省资源或者这些应用程序是为了完成某一共同工作,它们

      也可能会运行在一个进程里。

                                                                 

 

 

  知识点介绍:

            ActivityManager.RunningAppProcessInfo类          说明: 封装了正在运行的进程信息

         常用字段:

                   int   pid    进程ID

                   int   uid    进程所在的用户ID

                   String   processName 进程名,默认是包名或者由android:process=””属性指定

                   String [ ]   pkgList      运行在该进程下的所有应用程序包名

 

      关于ActivityManager.RunningAppProcessInfo更多信息,请查看

       PackageManger类

       说明: 封装了对应用程序信息的操作

        获得应用程序信息的的方法如下:

       public abstract ApplicationInfo  getApplicationInfo(String packageName, int flags)

          参数:packagename 包名

                       flags   该ApplicationInfo是此flags标记,通常可以直接赋予常数0即可

          功能:返回ApplicationInfo对象

 

   关于PackageManger更多信息,请查看

 

 

 Demo说明:

 

            我们利用ActivityManager获取所有正在运行的进程信息后,也就是获取了每个进程里正在运行的应用程序包名(pkgname),

     那么通过这些包名(pkgname),直接调用PackageManager类提供的方法,可以获取这些应用程序的信息了。

 

           一些资源文件就不贴了,直接贴出了主工程逻辑。需要注意的在这儿我们一次性获取了所有应用程序信息,然后对这些

     应用程序进行过滤,得到我们需要的对象。 读者可以使用PackageManager类提供的方法,进行循环遍历所有包名(pkgname),

     但是这样效率会比较低。

 

      截图如下:

                     点击某一进程后                                           查看某一进程运行的应用程序信息              所有正在运行的进程信息:

                                      

   

   显示正在运行应用程序的工程代码如下:

 

package com.qin.ammp; import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; import android.app.Activity; import android.app.ActivityManager; import android.content.Context; import android.content.Intent; import android.content.pm.ApplicationInfo; import android.content.pm.PackageInfo; import android.content.pm.PackageManager; import android.content.pm.PackageManager.NameNotFoundException; import android.os.Bundle; import android.util.Log; import android.view.View; import android.widget.AdapterView; import android.widget.ListView; import android.widget.TextView; import android.widget.AdapterView.OnItemClickListener; public class BrowseRunningAppActivity extends Activity { private static String TAG = "BrowseRunningAppActivity"; private ListView listview = null; private List mlistAppInfo = null; private TextView tvInfo = null ; private PackageManager pm; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.browse_app_list); listview = (ListView) findViewById(R.id.listviewApp); tvInfo = (TextView)findViewById(R.id.tvInfo) ; mlistAppInfo = new ArrayList(); // 查询某一特定进程的所有应用程序 Intent intent = getIntent(); //是否查询某一特定pid的应用程序 int pid = intent.getIntExtra("EXTRA_PROCESS_ID", -1); if ( pid != -1) { //某一特定经常里所有正在运行的应用程序 mlistAppInfo =querySpecailPIDRunningAppInfo(intent, pid); } else{ // 查询所有正在运行的应用程序信息: 包括他们所在的进程id和进程名 tvInfo.setText("所有正在运行的应用程序有-------"); mlistAppInfo = queryAllRunningAppInfo(); } BrowseRunningAppAdapter browseAppAdapter = new BrowseRunningAppAdapter(this, mlistAppInfo); listview.setAdapter(browseAppAdapter); } // 查询所有正在运行的应用程序信息: 包括他们所在的进程id和进程名 // 这儿我直接获取了系统里安装的所有应用程序,然后根据报名pkgname过滤获取所有真正运行的应用程序 private List queryAllRunningAppInfo() { pm = this.getPackageManager(); // 查询所有已经安装的应用程序 List listAppcations = pm.getInstalledApplications(PackageManager.GET_UNINSTALLED_PACKAGES); Collections.sort(listAppcations,new ApplicationInfo.DisplayNameComparator(pm));// 排序 // 保存所有正在运行的包名 以及它所在的进程信息 Map pgkProcessAppMap = new HashMap(); ActivityManager mActivityManager = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE); // 通过调用ActivityManager的getRunningAppProcesses()方法获得系统里所有正在运行的进程 List appProcessList = mActivityManager .getRunningAppProcesses(); for (ActivityManager.RunningAppProcessInfo appProcess : appProcessList) { int pid = appProcess.pid; // pid String processName = appProcess.processName; // 进程名 Log.i(TAG, "processName: " + processName + " pid: " + pid); String[] pkgNameList = appProcess.pkgList; // 获得运行在该进程里的所有应用程序包 // 输出所有应用程序的包名 for (int i = 0; i < pkgNameList.length; i++) { String pkgName = pkgNameList[i]; Log.i(TAG, "packageName " + pkgName + " at index " + i+ " in process " + pid); // 加入至map对象里 pgkProcessAppMap.put(pkgName, appProcess); } } // 保存所有正在运行的应用程序信息 List runningAppInfos = new ArrayList(); // 保存过滤查到的AppInfo for (ApplicationInfo app : listAppcations) { // 如果该包名存在 则构造一个RunningAppInfo对象 if (pgkProcessAppMap.containsKey(app.packageName)) { // 获得该packageName的 pid 和 processName int pid = pgkProcessAppMap.get(app.packageName).pid; String processName = pgkProcessAppMap.get(app.packageName).processName; runningAppInfos.add(getAppInfo(app, pid, processName)); } } return runningAppInfos; } // 某一特定经常里所有正在运行的应用程序 private List querySpecailPIDRunningAppInfo(Intent intent , int pid) { String[] pkgNameList = intent.getStringArrayExtra("EXTRA_PKGNAMELIST"); String processName = intent.getStringExtra("EXTRA_PROCESS_NAME"); //update ui tvInfo.setText("进程id为"+pid +" 运行的应用程序共有 : "+pkgNameList.length); pm = this.getPackageManager(); // 保存所有正在运行的应用程序信息 List runningAppInfos = new ArrayList(); // 保存过滤查到的AppInfo for(int i = 0 ; i


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有