成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Android 2.3關于StrictMode使用教程

移動開發 Android
Android 2.3關于StrictMode使用是本文要介紹的內容,主要是來了解并學習Android 2.3的內容,具體關于Android 2.3內容的詳解來看本文。

Android 2.3關于StrictMode使用是本文要介紹的內容,主要是來了解并學習Android 2.3的內容,具體關于Android 2.3內容的詳解來看本文。

ANR窗口產生的原因是多種多樣的。程序的主線程因為IO讀寫或網絡阻塞而導致被阻塞了,外部存儲設備被獨占了或系統負荷(load)過高(即不是自己編寫的程序的問題,可能是系統或者其他第三方程序導致的問題),都有可能導致ANR窗口的出現。

從Android 2.3開始提供了一個新的類StrictMode,可以幫助開發者改進他們的Android開發應用,StrictMode可以用于捕捉發生在應用程序

主線程中耗時的磁盤、網絡訪問或函數調用,可以幫助開發者使其改進程序,使主線程處理UI和動畫在磁盤讀寫和網絡操作時變得更平滑,避免主線程被阻塞,導致ANR窗口的發生。

下面簡要說明下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() 就包括了磁盤讀寫和網絡I/O  
  7.               .penaltyLog()   //打印logcat,當然也可以定位到dropbox,通過文件保存相應的log  
  8.               .build());  
  9.       StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder()  
  10.               .detectLeakedSqlLiteObjects() //探測SQLite數據庫操作  
  11.               .penaltyLog()  //打印logcat  
  12.               .penaltyDeath()  
  13.               .build());  
  14.   }  
  15.   super.onCreate();  

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

輸出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) 

小結:Android 2.3關于StrictMode使用教程的內容介紹完了,希望通過Android 2.3內容的學習能對你有所幫助。更多想要了解關于Android 2.3更多的內容,請參考編輯推薦。

責任編輯:zhaolei 來源: 博客園
相關推薦

2010-12-10 10:16:21

Android 2.3

2011-09-07 13:42:36

Android Wid實例

2010-12-07 09:30:58

Android 2.3

2014-06-24 10:34:08

Android Stu教程

2013-05-17 10:48:40

GoogleAndroid Stu

2011-09-14 10:11:35

Android 2.3

2011-02-21 16:39:47

Android 2.3Android R5

2012-12-25 13:37:29

Android代碼混淆

2015-01-04 09:58:06

Android 2.3

2010-12-13 14:41:44

Android 2.3MyEclipse

2014-07-17 11:36:27

Android Stu使用教程

2011-12-01 10:25:29

AndroidAndroid4.0冰淇淋三明治

2010-12-07 08:57:14

Android 2.3

2011-08-29 14:40:04

UbuntuAndroid

2011-10-21 14:57:32

QQ手機管家Android節電

2011-08-23 15:34:56

Lua模式 匹配

2011-09-02 13:51:00

PhoneGap框架HTML5

2010-06-22 16:09:42

Autoconf教程

2011-08-24 14:14:13

LUA環境 配置

2010-11-11 16:22:29

Android 2.3Android Gin
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲国产成人久久综合一区,久久久国产99 | 日本精品久久久久 | 久久精品99久久 | 国产福利在线视频 | 亚洲精品www久久久 www.蜜桃av | 日韩欧美在线观看视频 | 国产原创在线观看 | 精品国产黄a∨片高清在线 成人区精品一区二区婷婷 日本一区二区视频 | 中文字幕一区二区三区四区 | www亚洲精品| 国产区精品| 亚洲成人精品国产 | 国产精品一级 | 中文字幕第十一页 | 久草欧美 | 日韩色在线 | 在线色 | 伊人爽 | 精品九九九 | 久久99国产精品 | 国产精品无码专区在线观看 | 拍拍无遮挡人做人爱视频免费观看 | 欧美影院久久 | 久久69精品久久久久久国产越南 | 国产九九av | 亚洲国产精品一区在线观看 | 久久久91 | 看片91| 欧美一级全黄 | www成年人视频 | 日本韩国欧美在线观看 | 特级黄一级播放 | 国产视频精品视频 | 亚洲视频免费在线观看 | 精品国产乱码久久久久久中文 | 色综合色综合网色综合 | 青青99 | 2019中文字幕视频 | 欧美一级网站 | 久久国| 91精品国产91久久久 |