Android:StrictMode VmPolicy violation with POLICY_DEATH; android.os.NetworkOnMainThreadException

這幾天使用countly,然後發現在android4.0以上的系統,打開app就閃退瞭。

 

看瞭一下error log:

 

11-25 19:14:29.637: E/StrictMode(13886): class com.xx.mrnst.android.guide.SplashActivity; instances=2; limit=1

11-25 19:14:29.637: E/StrictMode(13886): android.os.StrictMode$InstanceCountViolation: class com.xx.mrnst.android.guide.SplashActivity; instances=2; limit=1

11-25 19:14:29.637: E/StrictMode(13886): at android.os.StrictMode.setClassInstanceLimit(StrictMode.java:1)

11-25 19:31:45.215: E/ConnectionManager(14418): android.os.NetworkOnMainThreadException

 

上網找瞭一些解決方案:

 

StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder()

.detectDiskReads()

.detectDiskWrites()

.detectNetwork() // 這裡可以替換為detectAll() 就包括瞭磁盤讀寫和網絡I/O

.penaltyLog() //打印logcat,當然也可以定位到dropbox,�?過文件保存相應的log

.build());

StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder()

.detectLeakedSqlLiteObjects() //探測SQLite數據庫操�?

.penaltyLog() //打印logcat

.penaltyDeath()

.build()); 

 

這個StrictMode的設置其實不管用的,

 

 

關鍵問題是網絡在主線程的優先級設置,如下所示:

 

if (android.os.Build.VERSION.SDK_INT > 9) {

   StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();

   StrictMode.setThreadPolicy(policy);

}

 

問題解決瞭。

 

 

這個問題在android 官方的介紹也挺令人困惑的,它提示你請求http不要放在主線程裡,其實我的程序基本上全在handler裡去發起請求;

 

不過我還沒有把全部handler全部使用AsyncTask 替換掉。

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *