Android中获取系统内存信息以及进程信息-----ActivityManager的使用(一)
本节内容主要是讲解ActivityManager的使用,通过ActivityManager我们可以获得系统里正在运行的activities,包括
进程(Process)等、应用程序/包、服务(Service)、任务(Task)信息。
计划如下:
第一部分:获取系统可用内存以及所有的正在运行的进程信息 ;
第二部分:获取每个进程里运行的应用程序信息和所有正在运行的应用程序
第三部分:获取正在运行的服务和任务信息。
每部分都准备了相应的Demo,助您更深的理解.
知识准备:Android 应用程序模块: 应用、任务、进程的知识介绍:
1 一个android 包(简称.apk) :里面包含应用程序的代码以及资源。这是一个应用发布,用户能下载并安装他们
设备上的文件。
2 一个 任务 :通常用户能当它为一个“应用程序”来启动:通常在桌面上会有一个图标可以来启动任务,这是一个
上层的应用,可以将你的任务切换到前台来。
3 一个 进程 :是一个底层的代码运行级别的核心进程。通常.apk包里所有代码运行在一个进程里,一个进程对于
一个.apk包;然而,进程 标签常用来改变代码运行的位置,可以是全部的.apk包 或者是独立的活动,接收器,服务, 或者
提供器组件。
进程
在Android中,进程是应用程序的完整实现,而不是用户通常了解的那样。他们主要用途很简单:
1、提高稳定性和安全性,将不信任或者不稳定的代码移动到其他进程。
2、可将多个.apk包运行在同一个进程里减少系统开销。
3、帮助系统管理资源,将重要的代码放在一个单独的进程里,这样就可以单独销毁应用程序的其他部分。
于是,为了完成某一任务或者减少系统资源的开销,一个进程里可以运行一个或多个应用程序。
更多知识点获取,请访问:《Android 应用程序模块: 应用, 任务, 进程, 和线程》
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<ProcessInfo> 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<ProcessInfo>();
- // 通过调用ActivityManager的getRunningAppProcesses()方法获得系统里所有正在运行的进程
- List<ActivityManager.RunningAppProcessInfo> 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大小,直接换算还是很简单的。
源代码地址:http://download.csdn.net/detail/qinjuning/3803314
Android中获取系统内存信息以及进程信息-----ActivityManager的使用(一)的更多相关文章
- Android中获取系统上安装的APP信息
Version:0.9 StartHTML:-1 EndHTML:-1 StartFragment:00000099 EndFragment:00003259 Android中获取系统上安装的APP信 ...
- MFC下获取系统内存和当前进程的内存使用情况
GlobalMemoryStatusEx来获取系统的内存使用情况 GetProcessMemoryInfo获取某个进程的内存使用情况.和任务管理器看到的是一样的. 具体代码如下: void GetSy ...
- Android中获取系统的时间
activity代码 public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); set ...
- python获取系统内存占用信息的实例方法
psutil是一个跨平台库(http://code.google.com/p/psutil/),能够轻松实现获取系统运行的进程和系统利用率(包括CPU.内存.磁盘.网络等)信息.它主要应用于系统监控, ...
- Android中如何查看内存
文章参照自:http://stackoverflow.com/questions/2298208/how-to-discover-memory-usage-of-my-application-in-a ...
- Android中如何查看内存(上)
文章参照自:http://stackoverflow.com/questions/2298208/how-to-discover-memory-usage-of-my-application-in-a ...
- Android中获取正在运行的应用程序-----ActivityManager.RunningAppProcessInfo类详解
今天继续讲解关于ActivityManager的使用,通过前面一节的学习,我们学会了如何利用ActivityManager获取系统里 正在运行的进程.本文要讲解的知识点是利用这些进程信息获取系统里正在 ...
- Android中获取正在运行的服务-------ActivityManager.RunningServiceInfo的使用
关于PackageManager和ActivityManager的使用 ,自己也写了一些DEMO 了,基本上写的线路参考了Settings模块下的 应用程序,大家如果真正的有所兴趣,建议大家看看源码, ...
- Android中获取应用程序(包)的大小-----PackageManager的使用(二)
通过第一部分<<Android中获取应用程序(包)的信息-----PackageManager的使用(一)>>的介绍,对PackageManager以及 AndroidMani ...
随机推荐
- 第六章 副词(Les adverbes )
副词属于不变词类,无性.数变化(tout除外),它的功能是修饰动词.形容词.副词或句子. ➡副词的构成 ⇨单一副词 bien tard hier mal vite tôt très souvent ...
- Django入门与实践-第18章:访问已登录用户(完结)
http://127.0.0.1:8000/boards/1/topics/1/ #boards/views.py @login_required def new_topic(request, pk) ...
- struts 拦截器
my-default.xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts ...
- day3之文件操作
一,文件操作基本流程. # 1.打开文件,产生文件句柄 # 2.操作文件句柄 # 3.关闭文件句柄 # f1 = open('11.txt',encoding='utf-8', mode='r') # ...
- 测试-LoadRunner
1录脚本 设置解析方式,html形式,会精炼成一个函数,此时找有用的url,写出函数:url方式,函数比较多. 参数化 两参数成对时,在脚本处选成对. 加上进程,加上返回值判断. 最后一段接口url, ...
- Java返回当前对象的好处
自己使用了一个第三方框架,发现非常的灵活,于是去研究了下,才知道是返回当前对象,才可以做到,例如以下案例: // 可以不断的点出很多函数 Glide.with(PhotoPagerSlitherAct ...
- 数据库选项--ALTER DATABASE WITH 选项
指定当数据库从一种状态转换到另一种状态时,何时回滚未完成的事务. 如果终止子句被忽略,则当数据库中存在任何锁时,ALTER DATABASE 语句将无限期等待. 只能指定一条终止子句,而且该子句应跟在 ...
- asp .net api 日志
方法1:继承IExceptionLogger ExceptionLogger是框架提供的表示未处理的异常记录器的抽象类 public class RecordExceptionLogger : Exc ...
- NVIC配置中的分组详解
在配置优先级的时候,要注意一个很重要的问题,中断种类的数量. NVIC只可以配置 16 种 中断向量的优先级,也就是说,抢占优先级和响应优先 级的数量由一个 4 位的数字来决定, 把这个 4 位数字的 ...
- WPF CompositionTarget
CompositionTarget 是一个类,表示其绘制你的应用程序的显示图面. WPF 动画引擎提供了许多用于创建基于帧的动画的功能. 但是,有应用程序方案中,您需要通过基于每个帧来呈现控件. Co ...