android異常:android.os.NetworkOnMainThreadException

報android.os.NetworkOnMainThreadException異常,通過查文檔,原來是4.0系統不容許主線程(UI線程)訪問網絡,所以致使了其異常。在4.0以後在主線程裏面執行Http請求都會報這個錯,也許是怕Http請求時間太長形成程序假死的狀況吧。 android

一:在發起Http請求的Activity裏面的onCreate函數裏面添加以下代碼: 網絡

//詳見StrictMode文檔 StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder().detectDiskReads().detectDiskWrites().detectNetwork().penaltyLog().build()); StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder().detectLeakedSqlLiteObjects().detectLeakedClosableObjects().penaltyLog().penaltyDeath().build());

若是正在作的項目不是Android 4.0的是看不到StrictMode類的。 ide

 

二:使用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() { // // TODO: http request. //  Message msg = new Message(); Bundle data = new Bundle(); data.putString("value","請求結果"); msg.setData(data); handler.sendMessage(msg); } }
開線程處理關於網絡的事物,而後用handler發送消息來處理更新UI。

本身走了很多彎路。 ui

相關文章
相關標籤/搜索