Google在android2.3中新增了StrictMode API來設定對一個thread的策略(ui線程或者分線程),它主要檢測了讀寫操作,訪問網路,資料庫讀寫等耗時的操作並將其以log或者dialog等形式列印出來。分析這些日誌,我們可以儘快找出程式運行緩慢的原因進而最佳化代碼,避免ANR(Application Not Responding)視窗的出現。
啟用StrictMode
推薦的使用StrictMode的方式是,在開發階段,開啟它,在發布應用前,關閉它。
例如:在你的應用中,onCreate():
Java代碼
- public void onCreate() {
-
- if (DEVELOPER_MODE) {
- StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder() //構造StrictMode
-
- .detectDiskReads() //當發生磁碟讀操作時輸出
-
- .detectDiskWrites()//當發生磁碟寫操作時輸出
-
- .detectNetwork() //訪問網路時輸出,這裡可以替換為detectAll() 就包括了磁碟讀寫和網路I/O
-
- .penaltyLog() //以日誌的方式輸出
-
- .build());
-
- StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder()
-
- .detectLeakedSqlLiteObjects() //探測SQLite資料庫操作
-
- .penaltyLog() //以日誌的方式輸出
-
- .penaltyDeath()
-
- .build());
-
- }
-
- super.onCreate();
-
-
當觸發策略中的操作時系統會列印出一條StrictMode日誌,格式如下:
Java代碼
- 02-27 10:03:56.122: DEBUG/StrictMode(16210): StrictMode policy violation; ~duration=696 ms: android.os.StrictMode$StrictModeDiskReadViolation: policy=23 violation=2
- 02 02-27 10:03:56.122: DEBUG/StrictMode(16210): at android.os.StrictMode$AndroidBlockGuardPolicy.onReadFromDisk(StrictMode.java:745)
另外說明兩點:
1.在android2.3版本直接在ui線程中訪問網路會報錯
2.ANR視窗會在程式阻塞或者耗時超過5秒的運算後彈出