这几天使用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 替换掉。