首页 > 代码库 > android.os.NetworkOnMainThreadException
android.os.NetworkOnMainThreadException
因为Http请求写在了主线程里, 在4.0之后在主线程里面执行Http请求都会报这个错,大概是怕Http请求时间太长造成程序假死的情况吧。
解决方法有两种,下面我分别介 绍:
第一种,是在主线程中直接忽略,强制执行。(不推荐这种方法,但是该方法修改起来简单)
在MainActivity文件的setContentView(R.layout.activity_main)下面加上如下代码
if (android.os.Build.VERSION.SDK_INT > 9) { StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build(); StrictMode.setThreadPolicy(policy); }
如果,有报错就在class头上加上
@TargetApi(Build.VERSION_CODES.GINGERBREAD)@SuppressLint("NewApi")
在onCreate上面加上:
@SuppressLint("NewApi")
第二种,启动另一个线程执行网络连接任务,比如使用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 = http://www.mamicode.com/msg.getData();"string">"value"); Log.i("mylog","请求结果-->" + val); }}Runnable runnable = new Runnable(){ @Override public void run() { // // TODO: http request. // Message msg = new Message(); Bundle data = http://www.mamicode.com/new Bundle(); data.putString("value","请求结果"); msg.setData(data); handler.sendMessage(msg); }}
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。