日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Android2.3關(guān)于StrictMode使用教程

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

在麒麟等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都做網(wǎng)站、網(wǎng)站制作 網(wǎng)站設(shè)計制作按需設(shè)計網(wǎng)站,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計,全網(wǎng)整合營銷推廣,外貿(mào)營銷網(wǎng)站建設(shè),麒麟網(wǎng)站建設(shè)費用合理。

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.(FileOutputStream.java:94)  
  6. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at java.io.FileOutputStream.(FileOutputStream.java:66)  
  7. 02-27 10:03:56.122: DEBUG/StrictMode(16210):     at java.io.FileWriter.(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.(FileOutputStream.java:94)  
  28. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at java.io.FileOutputStream.(FileOutputStream.java:66)  
  29. 02-27 10:03:56.162: DEBUG/StrictMode(16210):     at java.io.FileWriter.(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)容,請參考編輯推薦。


本文題目:Android2.3關(guān)于StrictMode使用教程
路徑分享:http://www.dlmjj.cn/article/cdsgppo.html