好久不寫(xiě)Android代碼手都生了,找出自己之前寫(xiě)的程序發(fā)現(xiàn)跑不了了,也沒(méi)啥特別的錯(cuò)誤提示,就看到一句有用的錯(cuò)誤Caused by: android.os.NetworkOnMainThreadException,查了下原因上在4.0之后在主線程里面執(zhí)行Http請(qǐng)求都會(huì)報(bào)這個(gè)錯(cuò),大概是怕Http請(qǐng)求時(shí)間太長(zhǎng)造成程序假死的情況吧。
解決辦法有兩個(gè)思路,分別是:
第一種方法:直接忽視,強(qiáng)制使用(強(qiáng)烈不推薦,但是修改簡(jiǎn)單)
在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);}
第二種方法:使用Thread、Runnable、Handler (推薦使用)
在Runnable中做HTTP請(qǐng)求,不用阻塞UI線程~
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","請(qǐng)求結(jié)果-->" + val); }}Runnable runnable = new Runnable(){ @Override public void run() { // // TODO: http request. // Message msg = new Message(); Bundle data = new Bundle(); data.putString("value","請(qǐng)求結(jié)果"); msg.setData(data); handler.sendMessage(msg); }}
附:另一篇解決方案
Android 4.1項(xiàng)目:使用新浪微博分享時(shí)報(bào):
android.os.NetworkOnMainThreadException
網(wǎng)上搜索后知道是因?yàn)榘姹締?wèn)題,在4.0之后在主線程里面執(zhí)行Http請(qǐng)求都會(huì)報(bào)這個(gè)錯(cuò),也許是怕Http請(qǐng)求時(shí)間太長(zhǎng)造成程序假死的情況吧。那么網(wǎng)上的朋友也給出了相應(yīng)的解決方案,這叫上有政策下有對(duì)策:
一:在發(fā)起Http請(qǐng)求的Activity里面的onCreate函數(shù)里面添加如下代碼:
//詳見(jiàn)StrictMode文檔StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder().detectDiskReads().detectDiskWrites().detectNetwork().penaltyLog().build());StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder().detectLeakedSqlLiteObjects().detectLeakedClosableObjects().penaltyLog().penaltyDeath().build());
如果正在做的項(xiàng)目不是Android 4.0的是看不到StrictMode類的。我也是用的網(wǎng)上給的com_weibo_android.jar。但是這個(gè)jar包下載下來(lái)的時(shí)候是2.3的,要先轉(zhuǎn)換成Android 4.0的項(xiàng)目,再在分享對(duì)應(yīng)的ShareActivity的onCreate()函數(shù)中添加上面的兩行代碼。這樣就不會(huì)報(bào)這個(gè)錯(cuò)誤了。
二:使用Thread、Runnable、Handler這三個(gè)類:
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","請(qǐng)求結(jié)果為-->" val); }}Runnable runnable = new Runnable(){ @Override public void run() { // // TODO: http request. // Message msg = new Message(); Bundle data = new Bundle(); data.putString("value","請(qǐng)求結(jié)果"); msg.setData(data); handler.sendMessage(msg); }}
新聞熱點(diǎn)
疑難解答
圖片精選