Android 4.1項目:使用新浪微博分享時報:android
android.os.NetworkOnMainThreadExceptionide
網上搜索後知道是由於版本問題,在4.0以後在主線程裏面執行Http請求都會報這個錯,也許是怕Http請求時間太長形成程序假死的狀況吧。那麼網上的朋友也給出了相應的解決方案,這叫上有政策下有對策:函數
一:在發起Http請求的Activity裏面的onCreate函數裏面添加以下代碼:ui
//詳見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類的。我也是用的網上給的com_weibo_android.jar。可是這個jar包下載下來的時候是2.3的,要先轉換成Android 4.0的項目,再在分享對應的ShareActivity的onCreate()函數中添加上面的兩行代碼。這樣就不會報這個錯誤了。this
二:使用Thread、Runnable、Handler這三個類:spa
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); } }
本身走了很多彎路。線程