Android編程實(shí)現(xiàn)獲取系統(tǒng)內(nèi)存、CPU使用率及狀態(tài)欄高度的方法示例
本文實(shí)例講述了Android編程實(shí)現(xiàn)獲取系統(tǒng)內(nèi)存、CPU使用率及狀態(tài)欄高度的方法。分享給大家供大家參考,具體如下:
DeviceInfoManage類用于獲取系統(tǒng)的內(nèi)存,CPU的信息,以及狀態(tài)欄的高度
import java.io.BufferedReader; import java.io.FileInputStream; import java.io.FileReader; import java.io.IOException; import java.io.InputStreamReader; import java.lang.reflect.Field; import java.util.List; import android.app.ActivityManager; import android.app.ActivityManager.RunningTaskInfo; import android.content.Context; public class DeviceInfoManager { // private static final String TAG = "DeviceInfoManager"; private static ActivityManager mActivityManager; public synchronized static ActivityManager getActivityManager(Context context) { if (mActivityManager == null) { mActivityManager = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE); } return mActivityManager; } /** * 用于獲取狀態(tài)欄的高度。 * * @return 返回狀態(tài)欄高度的像素值。 */ public static int getStatusBarHeight(Context context) { int statusBarHeight = 0; try { Class<?> c = Class.forName("com.android.internal.R$dimen"); Object o = c.newInstance(); Field field = c.getField("status_bar_height"); int x = (Integer) field.get(o); statusBarHeight = context.getResources().getDimensionPixelSize(x); } catch (Exception e) { e.printStackTrace(); } return statusBarHeight; } /** * 計(jì)算已使用內(nèi)存的百分比,并返回。 * * @param context * 可傳入應(yīng)用程序上下文。 * @return 已使用內(nèi)存的百分比,以字符串形式返回。 */ public static String getUsedPercentValue(Context context) { long totalMemorySize = getTotalMemory(); long availableSize = getAvailableMemory(context) / 1024; int percent = (int) ((totalMemorySize - availableSize) / (float) totalMemorySize * 100); return percent + "%"; } /** * 獲取當(dāng)前可用內(nèi)存,返回?cái)?shù)據(jù)以字節(jié)為單位。 * * @param context 可傳入應(yīng)用程序上下文。 * @return 當(dāng)前可用內(nèi)存。 */ public static long getAvailableMemory(Context context) { ActivityManager.MemoryInfo mi = new ActivityManager.MemoryInfo(); getActivityManager(context).getMemoryInfo(mi); return mi.availMem; } /** * 獲取系統(tǒng)總內(nèi)存,返回字節(jié)單位為KB * @return 系統(tǒng)總內(nèi)存 */ public static long getTotalMemory() { long totalMemorySize = 0; String dir = "/proc/meminfo"; try { FileReader fr = new FileReader(dir); BufferedReader br = new BufferedReader(fr, 2048); String memoryLine = br.readLine(); String subMemoryLine = memoryLine.substring(memoryLine.indexOf("MemTotal:")); br.close(); //將非數(shù)字的字符替換為空 totalMemorySize = Integer.parseInt(subMemoryLine.replaceAll("\\D+", "")); } catch (IOException e) { e.printStackTrace(); } return totalMemorySize; } /** * 獲取頂層activity的包名 * @param context * @return activity的包名 */ public static String getTopActivityPackageName(Context context) { ActivityManager activityManager = getActivityManager(context); List<RunningTaskInfo> runningTasks = activityManager.getRunningTasks(1); return runningTasks.get(0).topActivity.getPackageName(); } /** * 獲取當(dāng)前進(jìn)程的CPU使用率 * @return CPU的使用率 */ public static float getCurProcessCpuRate() { float totalCpuTime1 = getTotalCpuTime(); float processCpuTime1 = getAppCpuTime(); try { Thread.sleep(360); } catch (Exception e) { } float totalCpuTime2 = getTotalCpuTime(); float processCpuTime2 = getAppCpuTime(); float cpuRate = 100 * (processCpuTime2 - processCpuTime1) / (totalCpuTime2 - totalCpuTime1); return cpuRate; } /** * 獲取總的CPU使用率 * @return CPU使用率 */ public static float getTotalCpuRate() { float totalCpuTime1 = getTotalCpuTime(); float totalUsedCpuTime1 = totalCpuTime1 - sStatus.idletime; try { Thread.sleep(360); } catch (InterruptedException e) { e.printStackTrace(); } float totalCpuTime2 = getTotalCpuTime(); float totalUsedCpuTime2 = totalCpuTime2 - sStatus.idletime; float cpuRate = 100 * (totalUsedCpuTime2 - totalUsedCpuTime1) / (totalCpuTime2 - totalCpuTime1); return cpuRate; } /** * 獲取系統(tǒng)總CPU使用時(shí)間 * @return 系統(tǒng)CPU總的使用時(shí)間 */ public static long getTotalCpuTime() { 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]); sStatus.usertime = Long.parseLong(cpuInfos[2]); sStatus.nicetime = Long.parseLong(cpuInfos[3]); sStatus.systemtime = Long.parseLong(cpuInfos[4]); sStatus.idletime = Long.parseLong(cpuInfos[5]); sStatus.iowaittime = Long.parseLong(cpuInfos[6]); sStatus.irqtime = Long.parseLong(cpuInfos[7]); sStatus.softirqtime = Long.parseLong(cpuInfos[8]); return sStatus.getTotalTime(); } /** * 獲取當(dāng)前進(jìn)程的CPU使用時(shí)間 * @return 當(dāng)前進(jìn)程的CPU使用時(shí)間 */ public static long getAppCpuTime() { // 獲取應(yīng)用占用的CPU時(shí)間 String[] cpuInfos = null; try { int pid = android.os.Process.myPid(); BufferedReader reader = new BufferedReader(new InputStreamReader( new FileInputStream("/proc/" + pid + "/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]); return appCpuTime; } static Status sStatus = new Status(); static class Status { public long usertime; public long nicetime; public long systemtime; public long idletime; public long iowaittime; public long irqtime; public long softirqtime; public long getTotalTime() { return (usertime + nicetime + systemtime + idletime + iowaittime + irqtime + softirqtime); } } }
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android資源操作技巧匯總》、《Android視圖View技巧總結(jié)》、《Android操作XML數(shù)據(jù)技巧總結(jié)》、《Android編程之a(chǎn)ctivity操作技巧總結(jié)》、《Android文件操作技巧匯總》、《Android操作json格式數(shù)據(jù)技巧總結(jié)》、《Android開發(fā)入門與進(jìn)階教程》及《Android控件用法總結(jié)》
希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。
- 解決Android 高CPU占用率的問題
- Android、Flutter為不同的CPU架構(gòu)包打包APK(v7a、v8a、x86區(qū)別)
- Python獲取android設(shè)備cpu和內(nèi)存占用情況
- 淺析AndroidStudio3.0最新 Android Profiler分析器(cpu memory network 分析器)
- Android獲取設(shè)備CPU核數(shù)、時(shí)鐘頻率以及內(nèi)存大小的方法
- 解析Android獲取系統(tǒng)cpu信息,內(nèi)存,版本,電量等信息的方法詳解
- android獲取手機(jī)cpu并判斷是單核還是多核
- Android 輕松獲取CPU型號(hào)的方法
相關(guān)文章
Android?PopUpWindow實(shí)現(xiàn)卡片式彈窗
大家好,本篇文章主要講的是Android?PopUpWindow實(shí)現(xiàn)卡片式彈窗,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01淺談關(guān)于Android路由的實(shí)現(xiàn)
本篇文章主要介紹了淺談關(guān)于Android路由的實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10Android實(shí)現(xiàn)EditText的富文本編輯
這篇文章主要介紹了Android實(shí)現(xiàn)EditText的富文本編輯,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08Android手機(jī)注冊登錄時(shí)獲取驗(yàn)證碼之后倒計(jì)時(shí)功能(知識(shí)點(diǎn)總結(jié))
這篇文章主要介紹了Android手機(jī)注冊登錄時(shí)獲取驗(yàn)證碼之后倒計(jì)時(shí)(知識(shí)點(diǎn)總結(jié))功能,代碼簡單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-01-01Android自定義Camera實(shí)現(xiàn)拍照功能
這篇文章主要為大家詳細(xì)介紹了Android自定義Camera實(shí)現(xiàn)拍照功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05Android Intent與IntentFilter案例詳解
這篇文章主要介紹了Android Intent與IntentFilter案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08Android設(shè)計(jì)登錄界面、找回密碼、注冊功能
這篇文章主要為大家詳細(xì)介紹了Android設(shè)計(jì)登錄界面的方法,Android實(shí)現(xiàn)找回密碼、注冊功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05Android設(shè)置默認(rèn)鎖屏壁紙接口的方法
這篇文章主要介紹了Android默認(rèn)鎖屏壁紙接口的設(shè)置方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01SurfaceView播放視頻發(fā)送彈幕并實(shí)現(xiàn)滾動(dòng)歌詞
這篇文章主要為大家詳細(xì)介紹了SurfaceView播放視頻發(fā)送彈幕并實(shí)現(xiàn)滾動(dòng)歌詞,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11