博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android中获取系统内存信息以及进程信息-----ActivityManager的使用(一)
阅读量:7099 次
发布时间:2019-06-28

本文共 10919 字,大约阅读时间需要 36 分钟。

   本节内容主要是讲解ActivityManager的使用,通过ActivityManager我们可以获得系统里正在运行的activities,包括

     进程(Process)等、应用程序/包、服务(Service)、任务(Task)信息。

 

              计划如下:

                  第一部分:获取系统可用内存以及所有的正在运行的进程信息 ;

                  第二部分:获取每个进程里运行的应用程序信息和所有正在运行的应用程序

                  第三部分:获取正在运行的服务和任务信息。

 

        

                每部分都准备了相应的Demo,助您更深的理解.

 

           

        知识准备:Android 应用程序模块: 应用、任务、进程的知识介绍:

 

            1  一个android 包(简称.apk) :里面包含应用程序的代码以及资源。这是一个应用发布,用户能下载并安装他们

              设备上的文件。

            2  一个 任务 :通常用户能当它为一个“应用程序”来启动:通常在桌面上会有一个图标可以来启动任务,这是一个

              上层的应用,可以将你的任务切换到前台来。

            3  一个 进程 :是一个底层的代码运行级别的核心进程。通常.apk包里所有代码运行在一个进程里,一个进程对于

              一个.apk包;然而, 标签常用来改变代码运行的位置,可以是 或者是独立的,,, 或者

                 组件。

  进程

         在Android中,进程是应用程序的完整实现,而不是用户通常了解的那样。他们主要用途很简单:

            1、提高稳定性和安全性,将不信任或者不稳定的代码移动到其他进程。

            2、可将多个.apk包运行在同一个进程里减少系统开销。

            3、帮助系统管理资源,将重要的代码放在一个单独的进程里,这样就可以单独销毁应用程序的其他部分。

 

         于是,为了完成某一任务或者减少系统资源的开销,一个进程里可以运行一个或多个应用程序

 

     

    更多知识点获取,请访问:《

 

 

 

ActivityManager 类:

             获取方法 ActivityManager mActivityManager (ActivityManager)getSystemService(Context.ACTIVITY_SERVICE);

 

          常用的静态内部类如下(下面具体介绍):

 

                     ActivityManager.MemoryInfo: 系统可用内存信息

                      ActivityManager.RecentTaskInfo: 最近的任务信息

                      ActivityManager.RunningAppProcessInfo: 正在运行的进程信息

                      ActivityManager.RunningServiceInfo: 正在运行的服务信息

                      ActivityManager.RunningTaskInfo: 正在运行的任务信息

 

 

 常用方法:

 

public void getMemoryInfo(ActivityManager.MemoryInfo outInfo)

                说明:获取系统可用内存信息,数据封装在outInfo对象上

 

public Debug.MemoryInfo getProcessMemoryInfo(int[ ] pids

     说明:获取每个进程ID(集合)占用的内存大小(集合), pid和MemoryInfo是一一对应的。

     参数: pids 进程ID的集合            

PS :我们可以通过调用Debug.MemoryInfo 的dalvikPrivateDirty字段获取进程占用的内存大小(单位为KB)

 

 public List<ActivityManager.RunningAppProcessInfo>getRunningAppProcess()

    说明: 获取系统里正在运行的进程

public List<ActivityManager.RunningServiceInfo>getRunningServices(int maxNum)

     说明: 获取系统里所有正在运行的服务         

     参数:可能服务的最大值(赋予一常数即可,20、50都OK)

public List<ActivityManager.RunningTaskInfoo>getRunningTasks(int maxNum)

               说明:获取系统里正在运行的服务

               参数: 同上

 

public List<ActivityManager.RecentTaskInfo>getRecentTasks(int maxNum, int flags)

             说明:获取系统里最近启动的任务

             参数: 同上,flags一般为0即可

 

public voidkillBackgroundProcess(String packageName)

            说明:立即杀掉给定包名的进程,释放进程占用的资源(内存等),如果需要,系统会再次重新启动该进程。系统

            PS:系统进程是杀不死的,只能杀死用户进程。但我没有找到好的方法辨别系统进程还是用户进程。但可以肯定的是,

                   能够杀死的一定是用户进程。

 

          public void restartPackage(String packageName)

            说明:该方法已弃用,等同于killBackgroundProcess 。

 

 ActivityManager.MemoryInfo类

    常用字段:

            long availMem 系统可用内存

            long threshold系统内存不足的阀值,即临界值

            boolean lowMemory 如果当前可用内存<=threshold,该值为真

ActivityManager.RunningAppProcessInfo类

   常用字段:

          int pid                             进程ID

          int uid                             进程所在的用户ID

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

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

 

       对ActivityManager.RecentTaskInfo 、ActivityManager.RunningServiceInfo 、ActivityManager.RunningTaskInfo

   类的介绍留在后文介绍。

 

DEMO说明:

 

          我们通过ActivityManager获取了系统的可用内存信息以及正在运行在系统里的进程具体信息,当然你也可以选择

       手动杀死这些进程,不过前提是用户进程,因为系统进程是杀不死的。

 

          模拟器上的截图如下:

                                    

 

 

 

资源文件什么的就不再贴代码了,直接列出逻辑文件。

 

 

  获取系统可用内存的代码:MainActivity.java

package com.qin.ammp; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.app.ActivityManager; import android.app.ActivityManager.MemoryInfo; import android.content.Context; import android.content.Intent; import android.os.Bundle; import android.os.Debug; import android.text.format.Formatter; import android.util.Log; import android.view.View; import android.widget.Button; import android.widget.TextView; public class MainActivity extends Activity {
private static String TAG = "AM_MEMORYIPROCESS" ; private ActivityManager mActivityManager = null ; private TextView tvAvailMem ; private Button btProcessInfo ; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); setContentView(R.layout.main); tvAvailMem = (TextView)findViewById(R.id.tvAvailMemory) ; btProcessInfo =(Button)findViewById(R.id.btProcessInfo); //跳转到显示进程信息界面 btProcessInfo.setOnClickListener(new View.OnClickListener() {
@Override public void onClick(View v) {
// TODO Auto-generated method stub Intent intent = new Intent(MainActivity.this,BrowseProcessInfoActivity.class); startActivity(intent); } }); //获得ActivityManager服务的对象 mActivityManager = (ActivityManager)getSystemService(Context.ACTIVITY_SERVICE); //获得可用内存信息 String availMemStr = getSystemAvaialbeMemorySize(); Log.i(TAG, "The Availabel Memory Size is"+availMemStr); //显示 tvAvailMem.setText(availMemStr); } //获得系统可用内存信息 private String getSystemAvaialbeMemorySize(){
//获得MemoryInfo对象 MemoryInfo memoryInfo = new MemoryInfo() ; //获得系统可用内存,保存在MemoryInfo对象上 mActivityManager.getMemoryInfo(memoryInfo) ; long memSize = memoryInfo.availMem ; //字符类型转换 String availMemStr = formateFileSize(memSize); return availMemStr ; } //调用系统函数,字符串转换 long -String KB/MB private String formateFileSize(long size){
return Formatter.formatFileSize(MainActivity.this, size); } }

获取系统进程信息的代码 :BrowseProcessInfoActivity .java

package com.qin.ammp; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.app.ActivityManager; import android.app.AlertDialog; import android.app.Dialog; import android.content.Context; import android.content.DialogInterface; import android.os.Bundle; import android.os.Debug; import android.util.Log; import android.view.ContextMenu; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.ContextMenu.ContextMenuInfo; import android.widget.AdapterView; import android.widget.ListView; import android.widget.TextView; import android.widget.AdapterView.OnItemClickListener; public class BrowseProcessInfoActivity extends Activity  implements OnItemClickListener{
private static String TAG = "ProcessInfo"; private static final int KILL_PORCESS = 1; private static final int SEARCH_RUNNING_APP = 2; private ActivityManager mActivityManager = null; // ProcessInfo Model类 用来保存所有进程信息 private List
processInfoList = null; private ListView listviewProcess; private TextView tvTotalProcessNo ; public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); setContentView(R.layout.browse_process_list); listviewProcess = (ListView) findViewById(R.id.listviewProcess); listviewProcess.setOnItemClickListener(this); tvTotalProcessNo =(TextView)findViewById(R.id.tvTotalProcessNo); this.registerForContextMenu(listviewProcess); // 获得ActivityManager服务的对象 mActivityManager = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE); // 获得系统进程信息 getRunningAppProcessInfo(); // 为ListView构建适配器对象 BrowseProcessInfoAdapter mprocessInfoAdapter = new BrowseProcessInfoAdapter( this, processInfoList); listviewProcess.setAdapter(mprocessInfoAdapter); tvTotalProcessNo.setText("当前系统进程共有:"+processInfoList.size()); } //杀死该进程,并且刷新 @Override public void onItemClick(AdapterView
arg0, View arg1, final int position, long arg3) {
// TODO Auto-generated method stub new AlertDialog.Builder(this).setMessage("是否杀死该进程") .setPositiveButton("确定", new DialogInterface.OnClickListener() {
@Override public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub //杀死该进程,释放进程占用的空间 mActivityManager.killBackgroundProcesses(processInfoList.get(position).getProcessName()); //刷新界面 getRunningAppProcessInfo() ; BrowseProcessInfoAdapter mprocessInfoAdapter = new BrowseProcessInfoAdapter( BrowseProcessInfoActivity.this, processInfoList); listviewProcess.setAdapter(mprocessInfoAdapter); tvTotalProcessNo.setText("当前系统进程共有:"+processInfoList.size()); } }).setNegativeButton("取消", new DialogInterface.OnClickListener() {
@Override public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub dialog.cancel() ; } }).create().show() ; } // 获得系统进程信息 private void getRunningAppProcessInfo() {
// ProcessInfo Model类 用来保存所有进程信息 processInfoList = new ArrayList
(); // 通过调用ActivityManager的getRunningAppProcesses()方法获得系统里所有正在运行的进程 List
appProcessList = mActivityManager .getRunningAppProcesses(); for (ActivityManager.RunningAppProcessInfo appProcessInfo : appProcessList) {
// 进程ID号 int pid = appProcessInfo.pid; // 用户ID 类似于Linux的权限不同,ID也就不同 比如 root等 int uid = appProcessInfo.uid; // 进程名,默认是包名或者由属性android:process=""指定 String processName = appProcessInfo.processName; // 获得该进程占用的内存 int[] myMempid = new int[] { pid }; // 此MemoryInfo位于android.os.Debug.MemoryInfo包中,用来统计进程的内存信息 Debug.MemoryInfo[] memoryInfo = mActivityManager .getProcessMemoryInfo(myMempid); // 获取进程占内存用信息 kb单位 int memSize = memoryInfo[0].dalvikPrivateDirty; Log.i(TAG, "processName: " + processName + " pid: " + pid + " uid:" + uid + " memorySize is -->" + memSize + "kb"); // 构造一个ProcessInfo对象 ProcessInfo processInfo = new ProcessInfo(); processInfo.setPid(pid); processInfo.setUid(uid); processInfo.setMemSize(memSize); processInfo.setPocessName(processName); processInfoList.add(processInfo); // 获得每个进程里运行的应用程序(包),即每个应用程序的包名 String[] packageList = appProcessInfo.pkgList; Log.i(TAG, "process id is " + pid + "has " + packageList.length); for (String pkg : packageList) {
Log.i(TAG, "packageName " + pkg + " in process id is -->"+ pid); } } } public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) {
menu.add(0, 0, KILL_PORCESS, "杀死该进程"); menu.add(0, 0, SEARCH_RUNNING_APP, "运行在该进程的应用程序"); super.onCreateContextMenu(menu, v, menuInfo); } public boolean onContextItemSelected(MenuItem item) {
switch (item.getItemId()) {
case KILL_PORCESS: // 杀死该进程 , 重新加载界面 new AlertDialog.Builder(this).setMessage("是否杀死该进程") .setPositiveButton("确定", new DialogInterface.OnClickListener() {
@Override public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub } }).setNegativeButton("取消", new DialogInterface.OnClickListener() {
@Override public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub dialog.cancel() ; } }).create().show() ; break; case SEARCH_RUNNING_APP: // 查看运行在该进程的应用程序信息 break; default: break; } return super.onContextItemSelected(item); } }

我们可以通过进程占用内存大小来进而获取占用cpu大小,直接换算还是很简单的。

ref-src:http://blog.csdn.net/qinjuning/article/details/6978560

转载于:https://www.cnblogs.com/shanzei/archive/2012/03/29/2423987.html

你可能感兴趣的文章
Ansible源码解析Inventory主机概念
查看>>
Windows Server 2016-Win Ser 2016已删减内容
查看>>
LVS+Keepalived+Squid+Nginx高可用负载均衡缓存配置
查看>>
正则表达式口诀
查看>>
一个网站故障排查的、代码更新的简便脚本
查看>>
jQuery那坑爹的text()
查看>>
oracle log_archive_dest_1 未指定导致flash_recovery_area引发数据库挂起
查看>>
性能测试培训笔记-安装loadrunner出现vc2005_sp1_with_atl_fix_redist
查看>>
Puppet函数介绍(十八)
查看>>
awk学习笔记之行求和和列求和
查看>>
EtherChannel负载均衡
查看>>
mysql高可用方案之MMM
查看>>
企业级Nginx服务基础到架构优化详解--25条
查看>>
impdp导入数据时出现BUG
查看>>
在执行一个 scripts 时,在 scripts 内的变量, $0, $1 代表什么?
查看>>
Gartner:2016年十大信息安全技术(含解读)
查看>>
BYOD那些事
查看>>
symantec:硝基***针对化工厂商
查看>>
数据中心开发者定义
查看>>
Skype for Business Server 2015-04-前端服务器-0-准备
查看>>