Android项目实战--手机卫士27--拿到剩余内存以及正在运行的进程数

本文主要是介绍Android项目实战--手机卫士27--拿到剩余内存以及正在运行的进程数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



最新实战教程,让你了解Android自动化刷量、作弊与防作弊的那些事,案例:刷友盟统计、批量注册苹果帐号




昨天, 我们已经把程序锁这个功能给完成了,那么今天,我们就来做一下进程管理的功能,其实就是通过一个ActivityManager的对象来获取到这些信息的,所以也是挺简单的。

那么我们现在就来写一下这些代码。

首先,我们先来回顾一下我们之前说的,自定义title,我们是通过隐藏系统自己的title,然后再布局文件里面增加一些控件来达到自定义title的作用的,那么今天我们就讲一下另一种自定义title的方式。

		// 请求一个自己定义的title,但有一些Android系统是被修改过的,// 所以有可能是无法请求的,如乐Phone或小米的手机,这些系统是被修改过的,// 所以就要判断一下是否请求成功boolean flags = requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);setContentView(R.layout.process_manager);if (flags){// 设置自定义的titlegetWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE,R.layout.process_manager_title);}

大家可以看到,我们就是通过下面的几行代码来进行自定义title的,那么现在我们就学会了两种自定义title的方法啦,大家可以根据自己的需要来选择使用


上面只是设置好那个定义的代码,我们还要设置一下它的样式,不然就会只有25dip的啦,如何知道应该怎样设置这些值呢,我们之前讲过的,如果有什么不明白的,可以回去看我们之前的文章(自定义对话框),那么我们自定义title要修改的值也就只有两个啦



我们主要修改的也就是上面选定了的内容而已,所以我们现在在我们的style.xml里面写上几句样式

sytle.xml

    <style name="MyTitleBar" parent="@android:style/Theme"><item name="android:windowTitleSize">40dip</item><item name="android:windowTitleBackgroundStyle">@drawable/title_background</item></style>

那么我们写好了这些style就要应用它啦,那么我们是在那里应用它呢,就是在我们的activity的声明的时候啦,也就是在AndroidMainfest文件里面应用我们的style啦

AndroidMainfest.xml

        <activity android:theme="@style/MyTitleBar"android:label="@string/process_manager"android:name="com.xiaobin.security.ui.ProcessManagerActivity"></activity>

就这样子,我们的另一种自定义title就完成的啦,现在我们可以先给大家看看效果啦


好啦,上面的效果和我们隐藏自带的title, 然后自己用控件来实现差不多,大家可以根据自己的需要来选择实现方式


那么接下来,我们就要讲一下我们今天的主要内容啦,今天我们就是要把手机里面已经运行了的应用数目,以及手机里面剩余的内存数目啦

其实要拿到手机里面已经运行了的进程数目也很简单,只要我们拿到一个activityManager对象,然后再调用它的一个方法就可以的了

	//拿到当前运行的进程数目private int getRunningAppCount(){runningAppProcessInfos = activityManager.getRunningAppProcesses();return runningAppProcessInfos.size();}

activityManager.getRunningAppProcesses()拿到的是一个List<RunningAppProcessInfo>的列表,也就是运行的进程的信息的对象了,所以只要知道这个list里面有多少个对象,就可以知道有多少个进程在运行啦


拿到剩余的内存也比较简单,也是通过activityManager来获取的

	//拿到系统剩余的内存private String getAvailMemory(){//new一个内存的对象MemoryInfo memoryInfo = new ActivityManager.MemoryInfo();//拿到现在系统里面的内存信息activityManager.getMemoryInfo(memoryInfo);//拿到有效的内存空间long size = memoryInfo.availMem;return TextFormater.dataSizeFormat(size);}

大家可以看到,我们上面用了一个TextFormater的类,这个类是我们用来转换单位的啦

com.xiaobin.security.utils.TextFormater

package com.xiaobin.security.utils;import java.text.DecimalFormat;public class TextFormater
{public static String dataSizeFormat(long size){DecimalFormat formater = new DecimalFormat("####.00");if(size < 1024){return size + "byte";}else if(size < (1 << 20)) //左移20位,相当于1024 * 1024{float kSize = size >> 10; //右移10位,相当于除以1024return formater.format(kSize) + "KB";}else if(size < (1 << 30)) //左移30位,相当于1024 * 1024 * 1024{float mSize = size >> 20; //右移20位,相当于除以1024再除以1024return formater.format(mSize) + "MB";}else if(size < (1 << 40)){float gSize = size >> 30;return formater.format(gSize) + "GB";}else{return "size : error";}}}

好啦,到这里为止,我们的读取进程数目与读取剩余内存的数目就讲完的啦,下面我们把完整的activity和布局文件粘出来

com.xiaobin.security.ui.ProcessManagerActivity

package com.xiaobin.security.ui;import java.util.List;import android.app.Activity;
import android.app.ActivityManager;
import android.app.ActivityManager.MemoryInfo;
import android.app.ActivityManager.RunningAppProcessInfo;
import android.content.Context;
import android.os.Bundle;
import android.view.Window;
import android.widget.TextView;import com.xiaobin.security.R;
import com.xiaobin.security.utils.TextFormater;public class ProcessManagerActivity extends Activity
{private TextView tv_process_count;private TextView tv_process_memory;private ActivityManager activityManager;private List<RunningAppProcessInfo> runningAppProcessInfos;@Overrideprotected void onCreate(Bundle savedInstanceState){super.onCreate(savedInstanceState);activityManager = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE);// 请求一个自己定义的title,但有一些Android系统是被修改过的,// 所以有可能是无法请求的,如乐Phone或小米的手机,这些系统是被修改过的,// 所以就要判断一下是否请求成功boolean flags = requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);setContentView(R.layout.process_manager);if (flags){// 设置自定义的titlegetWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE,R.layout.process_manager_title);}tv_process_count = (TextView) findViewById(R.id.tv_process_count);tv_process_memory = (TextView) findViewById(R.id.tv_process_memory);initTitle();}//拿到当前运行的进程数目private int getRunningAppCount(){runningAppProcessInfos = activityManager.getRunningAppProcesses();return runningAppProcessInfos.size();}//拿到系统剩余的内存private String getAvailMemory(){//new一个内存的对象MemoryInfo memoryInfo = new ActivityManager.MemoryInfo();//拿到现在系统里面的内存信息activityManager.getMemoryInfo(memoryInfo);//拿到有效的内存空间long size = memoryInfo.availMem;return TextFormater.dataSizeFormat(size);}//设置title的信息private void initTitle(){tv_process_count.setText("进程数目:" + getRunningAppCount());tv_process_memory.setText("剩余内存:" + getAvailMemory());}}

process_manager.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:background="@android:color/white"android:orientation="vertical" ></LinearLayout>

process_manager_title.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="40dip"android:gravity="center_vertical"android:background="@drawable/title_background" ><TextView android:id="@+id/tv_process_count"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentLeft="true"android:layout_marginLeft="10dip"android:textColor="@android:color/white"android:text="@string/process_count"/><TextView android:id="@+id/tv_process_memory"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentRight="true"android:layout_marginRight="10dip"android:textColor="@android:color/white"android:text="@string/process_memory"/></RelativeLayout>

好啦,今天就讲到这里啦,接下来,我们都会讲这个进程管理的内容的啦


最后,和大家说一下

为了方便大家的交流,我创建了一个群,这样子大家有什么疑问也可以在群上交流

群号是298440981



今天源码下载




这篇关于Android项目实战--手机卫士27--拿到剩余内存以及正在运行的进程数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1045608

相关文章

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

PowerShell中15个提升运维效率关键命令实战指南

《PowerShell中15个提升运维效率关键命令实战指南》作为网络安全专业人员的必备技能,PowerShell在系统管理、日志分析、威胁检测和自动化响应方面展现出强大能力,下面我们就来看看15个提升... 目录一、PowerShell在网络安全中的战略价值二、网络安全关键场景命令实战1. 系统安全基线核查

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1