1.記憶體資訊
在proc/meminfo下有具體的記憶體使用情況,我這裡擷取的記憶體資訊就是從這個檔案中擷取的.擷取到具體的記憶體資訊後依據我自己的需求,從bufferdreader中單獨抽取出來了剩餘的記憶體容量.
<span style="font-family:Microsoft YaHei;font-size:14px;"> Runtime runtime = Runtime.getRuntime();
Process p;
try {
p = runtime.exec(CMD_MEM);
} catch (IOException e) {
Log.e("CameraActivity", "run cmd("+CMD_MEM+") failed:" + e.getMessage());
return null;
}
InputStreamReader reader = new InputStreamReader(p.getInputStream());
BufferedReader buf = new BufferedReader(reader);</span>
2.磁盤資訊
使用Android.os下的StatFs來擷取檔案系統狀态和一些磁盤資訊.
<span style="font-family:Microsoft YaHei;font-size:14px;"> File root = Environment.getRootDirectory();
StatFs sf = new StatFs(root.getPath());
long blockSize = sf.getBlockSize();
long availCount = sf.getAvailableBlocks();
return (availCount * blockSize) / 1024 / 1024 + "MB";</span>
3.CPU使用率,和目前程序的CPU占有率
3.1 CPU總使用率
在proc/stat下有具體的CPU使用情況.具體格式例如以下:
CPU 152342 1421 28562 1600830 12389 553 273 0 0
CPU後面的幾位數字各自是
user 從系統啟動開始累計到目前時刻。處于使用者态的執行時間,不包括 nice值為負程序。
nice 從系統啟動開始累計到目前時刻,nice值為負的程序所占用的CPU時間
system 從系統啟動開始累計到目前時刻,處于核心态的執行時間
idle
從系統啟動開始累計到目前時刻,除IO等待時間以外的其他等待時間
iowait 從系統啟動開始累計到目前時刻。IO等待時間
irq 從系統啟動開始累計到目前時刻,硬中斷時間
softirq 從系統啟動開始累計到目前時刻。軟中斷時間
是以totalCpuTime這個7個屬性的和.
CPU總數用率的算法是:100*((totalCpuTimeS-totalCpuTimeF) -(idelS-idelF))/ (totalCpuTimeS-totalCpuTim
eF)
3.2 目前程序的CPU使用率
/proc/pid/stat下則是該pid的CPU使用情況.具體格式例如以下:
2341 (cn.jesse.camera) S 1131 1131 0 0 -1 3912246 12450 0 2 0
3321 612 0 0 20 0
當中淡紅色的四位數字各自是:
utime 該任務在使用者執行狀态的時間
stime 該任務在核心執行的時間
cutime 全部已死線程在使用者狀态執行狀态的時間
cstime 全部已死線程在核心的執行時間
是以processCpuTime為這個四個屬性的和.
<span style="font-family:Microsoft YaHei;font-size:14px;"> 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){
Log.e(TAG, "IOException" + ex.toString());
return 0;
}
long totalCpu = 0;
try{
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]);
}catch(ArrayIndexOutOfBoundsException e){
Log.i(TAG, "ArrayIndexOutOfBoundsException" + e.toString());
return 0;
}</span>
<span style="font-family:Microsoft YaHei;font-size:14px;"> 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 e){
Log.e(TAG, "IOException" + e.toString());
return 0;
}
long appCpuTime = 0;
try{
appCpuTime = Long.parseLong(cpuInfos[13])
+ Long.parseLong(cpuInfos[14]) + Long.parseLong(cpuInfos[15])
+ Long.parseLong(cpuInfos[16]);
}catch(ArrayIndexOutOfBoundsException e){
Log.i(TAG, "ArrayIndexOutOfBoundsException" + e.toString());
return 0;
}</span>