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 替换掉。


你可能感兴趣的:(Android4.0)