Android獲取cpu使用率,剩餘內存和硬盤容量

1.內存信息

在proc/meminfo下有詳細的內存使用情況,我這裡獲取的內存信息就是從這個文件裡獲取的.獲取到詳細的內存信息後根據我自己的需求,從bufferdreader中單獨抽取出來瞭剩餘的內存容量.

		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);

2.磁盤信息

使用Android.os下的StatFs來獲取文件系統狀態和一些磁盤信息.

		File root = Environment.getRootDirectory();
		StatFs sf = new StatFs(root.getPath());
		long blockSize = sf.getBlockSize();
		long availCount = sf.getAvailableBlocks();
		return (availCount * blockSize) / 1024 / 1024 + "MB";

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為這個四個屬性的和.

當前進行所占CPU的算法是:100*(processCpuTimeS-processCpuTimeF)/(totalCpuTimeS-totalCpuTimeF)

		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;
		}

		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;
		}

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。