zoukankan      html  css  js  c++  java
  • android里常用的几个性能指标获取方法(纯代码)

    分享几个自己用过的获取app性能几个性能指标的代码

    获取对应进程内存占用信息:

     1     public void MemMonitor(){
     2 
     3 
     4        new Thread() {
     5                public void run() {
     6                    final ActivityManager ActivityList=(ActivityManager)getApplicationContext().getSystemService(ACTIVITY_SERVICE);
     7                    try {
     8                        Runtime.getRuntime().exec("am start --user 0 -n 包名/mainactivity名");
     9                        starttime=System.currentTimeMillis();
    10 
    11                    } catch (IOException e) {
    12                        Log.e("baih","启动应用失败");
    13                    }
    14                    while (true) {
    15                        Log.e("baih", "开始计算.....");
    16                        ActivityManager.MemoryInfo Mem1 = new ActivityManager.MemoryInfo();
    17                        ActivityList.getMemoryInfo(Mem1);
    18                        Long MemSize = Mem1.availMem;
    19                        Long Mem12=Mem1.threshold;
    20                        String leftMemSize = Formatter.formatFileSize(getBaseContext(), MemSize);
    21                        String leftMemSize1 = Formatter.formatFileSize(getBaseContext(), Mem12);
    22 
    23                        //获取受控极限堆值,获取非受控极限堆值
    24                        int i=ActivityList.getMemoryClass();//受控堆
    25                        int y=ActivityList.getLargeMemoryClass();//非受控堆
    26 
    27                        //计算进程内存占用
    28                        List<ActivityManager.RunningAppProcessInfo> AppList = ActivityList.getRunningAppProcesses();
    29                        for (ActivityManager.RunningAppProcessInfo am : AppList) {
    30                            if (am.processName.equals("包名")) {
    31                                long startedtime=System.currentTimeMillis();
    32                                long time=startedtime-starttime;
    33                                Log.e("baih","启动时间为:"+time+"MS");
    34                                int[] CMpid=new int[]{am.pid};
    35                                Debug.MemoryInfo[] MemInfo = ActivityList.getProcessMemoryInfo(CMpid);
    36                                AppPid=am.pid;
    37                                double MemorySize1 = MemInfo[0].dalvikPrivateDirty / 1024.0;
    38                                int temp = (int) (MemorySize1 * 100);
    39                                MemorySize1 = temp / 100.0;
    40                                String ProInfo = "";
    41                                ProInfo += "本机内存阀值:" + i + "MB
      " +
    42                                        "程序包名:" + am.processName + "   " + "
    PID:" + am.pid
    43                                        + "  " + "
    内存占用:" + MemorySize1 + "MB
    " + "
    ";
    44                                Log.e("baih", ProInfo);
    45                                if(AppPid!=0)
    46                                {
    47                                    Cpuinfo();//调用计算CPU占用率函数
    48                                }
    49 
    50                                Mem1 = null;
    51                                System.gc();
    52                                break;
    53                            } else {
    54                                Log.e("baih", "被测应用未运行");
    55                                Mem1 = null;
    56                                System.gc();
    57                                break;
    58                            }
    59                        }
    60                        try {
    61                            Thread.sleep(5000);
    62                        } catch (InterruptedException e) {
    63                            // TODO Auto-generated catch block
    64                            e.printStackTrace();
    65                        }
    66                    }
    67                }
    68            }.start();
    69 
    70    }

    获取进程CPU占用率:

        //计算CPU总使用时间
        private static long getTotalCpuTime() { // 获取系统总CPU使用时间
            String[] cpuInfos = null;
            try {
                BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream("/proc/stat")), 1000);
                String load = reader.readLine();
                reader.close();
                cpuInfos = load.split(" ");
            } catch (IOException ex) {
                ex.printStackTrace();
            }
            long totalCpu = Long.parseLong(cpuInfos[2])
                    + Long.parseLong(cpuInfos[3]) + Long.parseLong(cpuInfos[4])
                    + Long.parseLong(cpuInfos[6]) + Long.parseLong(cpuInfos[5])
                    + Long.parseLong(cpuInfos[7]) + Long.parseLong(cpuInfos[8])+Long.parseLong(cpuInfos[9])+Long.parseLong(cpuInfos[10]);
            //Log.e("baih", "CPU总使用时间:" + totalCpu + "======" + op);
    
            return totalCpu;
        }
    
        //计算进程使用CPU时间
        private static long getAppCpuTime() { // 获取应用占用的CPU时间
            String[] cpuInfos = null;
            try {
                BufferedReader reader = new BufferedReader(new InputStreamReader(
                        new FileInputStream("/proc/" +AppPid + "/stat")), 1000);
                String load = reader.readLine();
                reader.close();
                cpuInfos = load.split(" ");
            } catch (IOException ex) {
                ex.printStackTrace();
            }
            long appCpuTime = Long.parseLong(cpuInfos[13])
                    + Long.parseLong(cpuInfos[14]) + Long.parseLong(cpuInfos[15])
                    + Long.parseLong(cpuInfos[16]);
            //Log.e("baih", "应用使用CPU时间:" + appCpuTime);
            return appCpuTime;
        }
    
        //计算进程占用CPU率
        public void Cpuinfo(){    //计算CPU占用率
    
            new Thread(){
                public void run(){
                        long TotalCpu1 = getTotalCpuTime();
                        long AppCpu1 = getAppCpuTime();
    
                        try {
                            Thread.sleep(3000);
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
    
                        long TotalCpu2 = getTotalCpuTime();
                        long AppCpu2 = getAppCpuTime();
    
                        long CpuInfo = 100 * (AppCpu2 - AppCpu1) / (TotalCpu2 - TotalCpu1);
                        Log.e("baih", "CPU占用率=" + CpuInfo + "%");
    
                        try {
                            Thread.sleep(3000);
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                    }
            }.start();
        }

    获取应用启动时间:

        public void StartTime(){    //计算启动时间
            ActivityManager ac1=(ActivityManager)getApplicationContext().getSystemService(ACTIVITY_SERVICE);
            List<ActivityManager.RunningAppProcessInfo> Applist1=ac1.getRunningAppProcesses();
            while (true) {
                for (ActivityManager.RunningAppProcessInfo mc1 : Applist1) {
                    if (mc1.processName.equals("包名")) {
                        startedtime = System.currentTimeMillis();
                        continue;
                    } else {
                        starttime = System.currentTimeMillis();
                    }
                }
    
                time = startedtime - starttime;
    
                Log.e("baih", "启动时间为:" + time + "ms");
            }
    
        }
  • 相关阅读:
    iptables防火墙--------基本操作
    iptables防火墙--------基本概念
    常用运维工具小结
    ELK6.6.0+filebeat6.6.0部署
    Yum安装时出现 The program yum-complete-transaction is found in the yum-utils package
    重温面向对象核心 下 : 你一定能看懂的委托和事件
    重温面向对象核心 上
    程序员创业第一步:如何获取第一笔风险投资
    MVC + EFCore 完整教程19-- 最简方法读取json配置:自定义configuration读取配置文件
    MVC+EFCore 完整教程18 -- 升级分布视图至 View Component
  • 原文地址:https://www.cnblogs.com/cologne/p/4776647.html
Copyright © 2011-2022 走看看