自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Android 2.3關(guān)于StrictMode使用教程

移動開發(fā) Android
Android 2.3關(guān)于StrictMode使用是本文要介紹的內(nèi)容,主要是來了解并學(xué)習(xí)Android 2.3的內(nèi)容,具體關(guān)于Android 2.3內(nèi)容的詳解來看本文。

Android 2.3關(guān)于StrictMode使用是本文要介紹的內(nèi)容,主要是來了解并學(xué)習(xí)Android 2.3的內(nèi)容,具體關(guān)于Android 2.3內(nèi)容的詳解來看本文。

ANR窗口產(chǎn)生的原因是多種多樣的。程序的主線程因為IO讀寫或網(wǎng)絡(luò)阻塞而導(dǎo)致被阻塞了,外部存儲設(shè)備被獨占了或系統(tǒng)負(fù)荷(load)過高(即不是自己編寫的程序的問題,可能是系統(tǒng)或者其他第三方程序?qū)е碌膯栴}),都有可能導(dǎo)致ANR窗口的出現(xiàn)。

從Android 2.3開始提供了一個新的類StrictMode,可以幫助開發(fā)者改進(jìn)他們的Android開發(fā)應(yīng)用,StrictMode可以用于捕捉發(fā)生在應(yīng)用程序

主線程中耗時的磁盤、網(wǎng)絡(luò)訪問或函數(shù)調(diào)用,可以幫助開發(fā)者使其改進(jìn)程序,使主線程處理UI和動畫在磁盤讀寫和網(wǎng)絡(luò)操作時變得更平滑,避免主線程被阻塞,導(dǎo)致ANR窗口的發(fā)生。

下面簡要說明下Android 2.3新特性StrictMode限制模式的工作方式,見下面的代碼:

  1. public void onCreate() {  
  2.   if (DEVELOPER_MODE) {  
  3.       StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder()  
  4.               .detectDiskReads()  
  5.               .detectDiskWrites()  
  6.               .detectNetwork()   // 這里可以替換為detectAll() 就包括了磁盤讀寫和網(wǎng)絡(luò)I/O  
  7.               .penaltyLog()   //打印logcat,當(dāng)然也可以定位到dropbox,通過文件保存相應(yīng)的log  
  8.               .build());  
  9.       StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder()  
  10.               .detectLeakedSqlLiteObjects() //探測SQLite數(shù)據(jù)庫操作  
  11.               .penaltyLog()  //打印logcat  
  12.               .penaltyDeath()  
  13.               .build());  
  14.   }  
  15.   super.onCreate();  

上述代碼可以在Application的OnCreate中添加,這樣就能在程序啟動的最初一刻進(jìn)行監(jiān)控了。

輸出log如下:

  1. 02-27 10:03:56.122: DEBUG/StrictMode(16210): StrictMode policy violation; ~duration=696 ms:   
  2.                                                     android.os.StrictMode$StrictModeDiskReadViolation: policy=23 violation=2 
  3. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at android.os.StrictMode$AndroidBlockGuardPolicy.onReadFromDisk(StrictMode.java:745)  
  4. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at dalvik.system.BlockGuard$WrappedFileSystem.open(BlockGuard.java:228)  
  5. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at java.io.FileOutputStream.<init>(FileOutputStream.java:94)  
  6. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at java.io.FileOutputStream.<init>(FileOutputStream.java:66)  
  7. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at java.io.FileWriter.<init>(FileWriter.java:42)  
  8. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at org.zelos.asm.main.writeFile(main.java:30)  
  9. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at org.zelos.asm.main.onCreate(main.java:19)  
  10. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)  
  11. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)  
  12. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)  
  13. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)  
  14. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)  
  15. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at android.os.Handler.dispatchMessage(Handler.java:99)  
  16. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at android.os.Looper.loop(Looper.java:123)  
  17. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at android.app.ActivityThread.main(ActivityThread.java:3683)  
  18. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at java.lang.reflect.Method.invokeNative(Native Method)  
  19. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at java.lang.reflect.Method.invoke(Method.java:507)  
  20. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)  
  21. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)  
  22. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at dalvik.system.NativeStart.main(Native Method)  
  23. 02-27 10:03:56.162: DEBUG/StrictMode(16210): StrictMode policy violation; ~duration=619 ms:   
  24.                                                     android.os.StrictMode$StrictModeDiskWriteViolation: policy=23 violation=1 
  25. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at android.os.StrictMode$AndroidBlockGuardPolicy.onWriteToDisk(StrictMode.java:732)  
  26. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at dalvik.system.BlockGuard$WrappedFileSystem.open(BlockGuard.java:230)  
  27. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at java.io.FileOutputStream.<init>(FileOutputStream.java:94)  
  28. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at java.io.FileOutputStream.<init>(FileOutputStream.java:66)  
  29. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at java.io.FileWriter.<init>(FileWriter.java:42)  
  30. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at org.zelos.asm.main.writeFile(main.java:30)  
  31. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at org.zelos.asm.main.onCreate(main.java:19)  
  32. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)  
  33. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)  
  34. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)  
  35. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)  
  36. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)  
  37. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at android.os.Handler.dispatchMessage(Handler.java:99)  
  38. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at android.os.Looper.loop(Looper.java:123)  
  39. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at android.app.ActivityThread.main(ActivityThread.java:3683)  
  40. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at java.lang.reflect.Method.invokeNative(Native Method)  
  41. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at java.lang.reflect.Method.invoke(Method.java:507)  
  42. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)  
  43. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)  
  44. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at dalvik.system.NativeStart.main(Native Method) 

小結(jié):Android 2.3關(guān)于StrictMode使用教程的內(nèi)容介紹完了,希望通過Android 2.3內(nèi)容的學(xué)習(xí)能對你有所幫助。更多想要了解關(guān)于Android 2.3更多的內(nèi)容,請參考編輯推薦。

責(zé)任編輯:zhaolei 來源: 博客園
相關(guān)推薦

2010-12-10 10:16:21

Android 2.3

2011-09-07 13:42:36

Android Wid實例

2011-09-14 10:11:35

Android 2.3

2013-05-17 10:48:40

GoogleAndroid Stu

2010-12-07 09:30:58

Android 2.3

2014-06-24 10:34:08

Android Stu教程

2011-02-21 16:39:47

Android 2.3Android R5

2010-12-13 14:41:44

Android 2.3MyEclipse

2015-01-04 09:58:06

Android 2.3

2012-12-25 13:37:29

Android代碼混淆

2010-12-07 08:57:14

Android 2.3

2014-07-17 11:36:27

Android Stu使用教程

2011-12-01 10:25:29

AndroidAndroid4.0冰淇淋三明治

2011-10-21 14:57:32

QQ手機(jī)管家Android節(jié)電

2011-08-29 14:40:04

UbuntuAndroid

2010-11-25 10:24:13

2011-04-02 14:14:19

Android SDKEclipse

2011-09-02 13:51:00

PhoneGap框架HTML5

2011-08-23 15:34:56

Lua模式 匹配

2011-10-19 16:55:27

Android 2.3Android 4.0冰激凌三明治
點贊
收藏

51CTO技術(shù)棧公眾號