編輯:關於Android編程
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; }
(一)概述本節給大家帶來的是Android四大組件中的最後一個——ContentProvider(內容提供者),可能部分讀者 有疑問了,&rdqu
上圖Tab的背景效果,和帶陰影的圓角矩形,是怎麼實現的呢?大部分的人會讓美工切圖,用點九圖做背景。但是,如果只提供一張圖,會怎麼樣呢?比如,中間的Tab背景紅色底線的像素
記得一年前安卓開始火爆的時候,網上就有各種各樣的Windows下安裝安卓環境。很復雜,當時筆者在想,如果有人能開發Windows下一鍵安裝安卓模擬器那就火了
兩行代碼,用最簡單的方式來實現Android視圖擴散切換效果。一、概述這兩天時間動手撸了個視圖擴散切換效果的控制器,API兼容至Android4.0,更方便我們在視圖切