產生的緣由。官方解釋:html
Class Overview The exception that is thrown when an application attempts to perform a networking operation on its main thread. This is only thrown for applications targeting the Honeycomb SDK or higher. Applications targeting earlier SDK versions are allowed to do networking on their main event loop threads, but it's heavily discouraged. See the document Designing for Responsiveness. Also see StrictMode.
http://developer.android.com/intl/zh-cn/reference/android/os/NetworkOnMainThreadException.html
java
上面的意思是,從SDK3.0開始,google再也不贊成網絡請求(HTTP、Socket)等相關操做直接在主線程中。事實上原本就不該該這樣作,直接在UI線程進行網絡操做。會堵塞UI、用戶體驗很差。
也就是說。在SDK3.0如下的版本號,還可以繼續在主線程裏這樣作,在3.0以上,就不行了。因此。在如下的代碼中。使用Thread、Runnable、Handler這三個類:
android
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); this.setContentView(R.layout.test); // 開啓一個子線程。進行網絡操做。等待有返回結果,使用handler通知UI new Thread(networkTask).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); // UI界面的更新等相關操做 } }; /** * 網絡操做相關的子線程 */ Runnable networkTask = new Runnable() { @Override public void run() { // 在這裏進行 http request.網絡請求相關操做 MobEventService.postonKillProcess(context); Message msg = new Message(); Bundle data = new Bundle(); data.putString("value", "請求結果"); msg.setData(data); handler.sendMessage(msg); } };
class DownImage extends AsyncTask { private ImageView imageView; public DownImage(ImageView imageView) { this.imageView = imageView; } @Override protected Bitmap doInBackground(String... params) { String url = params[0]; Bitmap bitmap = null; try { //載入一個網絡圖片 InputStream is = new URL(url).openStream(); bitmap = BitmapFactory.decodeStream(is); } catch (Exception e) { e.printStackTrace(); } return bitmap; } @Override protected void onPostExecute(Bitmap result) { imageView.setImageBitmap(result); } }
if (android.os.Build.VERSION.SDK_INT > 9) { StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build(); StrictMode.setThreadPolicy(policy); }請記住,假設在主線程裏聲明瞭一個handler。這個handler所Post 的 Runnable(Thread)、以及處理的message都是在當前的主線程裏。非子線程。