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

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

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

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

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

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

主線程中耗時的磁盤、網(wǎng)絡訪問或函數(shù)調(diào)用,可以幫助開發(fā)者使其改進程序,使主線程處理UI和動畫在磁盤讀寫和網(wǎng)絡操作時變得更平滑,避免主線程被阻塞,導致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)絡I/O  
  7.               .penaltyLog()   //打印logcat,當然也可以定位到dropbox,通過文件保存相應的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中添加,這樣就能在程序啟動的最初一刻進行監(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)容的學習能對你有所幫助。更多想要了解關(guān)于Android 2.3更多的內(nèi)容,請參考編輯推薦。

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

2010-12-10 10:16:21

Android 2.3

2011-09-07 13:42:36

Android Wid實例

2013-05-17 10:48:40

GoogleAndroid Stu

2011-09-14 10:11:35

Android 2.3

2014-06-24 10:34:08

Android Stu教程

2010-12-07 09:30:58

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-10-21 14:57:32

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

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環(huán)境 配置

2011-08-29 14:40:04

UbuntuAndroid

2010-11-25 10:24:13

點贊
收藏

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

主站蜘蛛池模板: 日韩中文一区二区三区 | 免费v片| 日韩蜜桃视频 | 久久777| 91 中文字幕 | 久久久久国产一区二区三区四区 | 99re在线视频免费观看 | 青娱乐av | 91久久精品一区二区二区 | 久久精品视频在线免费观看 | 成人深夜福利 | 精品国产三级 | 91在线视频在线观看 | 国产福利在线播放 | 国产伦精品一区二区三区高清 | 黄色在线观看国产 | 国产精品成人一区二区三区 | 午夜无码国产理论在线 | 看一级毛片视频 | 日韩中出| 激情综合五月 | 成人网av| 亚洲国产成人在线视频 | 在线观看a视频 | av看片网| 成人免费一区二区 | 亚洲国产精品人人爽夜夜爽 | 国产精品久久久久久久久久久久冷 | 精品亚洲一区二区三区四区五区 | 伊人伊成久久人综合网站 | 一级毛片免费完整视频 | 天天精品在线 | 欧美精品黄| 一区精品视频在线观看 | 婷婷99| 男人天堂视频在线观看 | 免费av观看 | 国产精品综合视频 | 无码一区二区三区视频 | 天天夜碰日日摸日日澡 | 中文字幕国产高清 |