首页 > 移动平台 > 详细

android.os.NetworkOnMainThreadException 解决办法:

时间:2014-09-15 14:26:29      阅读:201      评论:0      收藏:0      [点我收藏+]

产生的原因:

在4.0之后在主线程里面执行Http请求都会报这个错,也许是怕Http请求时间太长造成程序假死的情况

解决办法:

1.在发起Http请求的Activity里面的onCreate函数里面添加如下代码

StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder().detectDiskReads().detectDiskWrites().detectNetwork().penaltyLog().build());
        StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder().detectLeakedSqlLiteObjects().detectLeakedClosableObjects().penaltyLog().penaltyDeath().build());

2.使用Thread、Runnable、Handler这三个类

public void onCreate(Bundle savedInstanceState) {   
 super.onCreate(savedInstanceState);  
  this.setContentView(R.layout.share_mblog_view); 
   new Thread(runnable).start();
}

Handler handler = new Handler(){
    @Override   
 public void handleMessage(Message msg) {      
        super.handleMessage(msg);
        Bundle data = msg.getData();
        String val = data.getString("value");
        Log.i("mylog","请求结果为-->" + val);
    }
}

Runnable runnable = new Runnable(){
    @Override   
    public void run() {      
        Message msg = new Message();
        Bundle data = new Bundle();
        data.putString("value","请求结果");
        msg.setData(data);
        handler.sendMessage(msg);
    }
}


android.os.NetworkOnMainThreadException 解决办法:

原文:http://my.oschina.net/arrom/blog/313664

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!