从字面意思大概可以猜出:在主线程访问网络发生了异常。
实际上在android4.0以后,在主线程中不允许访问网络(也有方法可以强制在主线程中访问,当然这种方式不推荐),主要是因为访问网络一般都比较耗时,容易阻塞UI线程,引起ANP。解决这个问题很简单:另外启动线程或者在服务中访问网络操作。
强制在主线程中访问网络,需要在主线程中增加如下代码(API9或者以上才能使用):
StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder()
.detectDiskReads()
.detectDiskWrites()
.detectNetwork()
.penaltyLog()
.build());
StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder()
.detectLeakedSqlLiteObjects()
.detectLeakedClosableObjects()
.penaltyLog()
.penaltyDeath()
.build());