android.os.NetworkOnMainThreadException異常

這個異常大概意思是在主線程訪問網絡時出的異常。 Android在4.0之前的版本 支持在主線程中訪問網絡,但是在4.0以後對這部分程序進行了優化,也就是說訪問網絡的代碼不能寫在主線程中了。

那麼如何做才能正常運行呢? 請看這裏:

例如:  從網絡中獲取一個Url地址。

  1. url = AuthUtil.getAuthorizationURL();  

  2. if (url == null) {  

  3.    Toast.makeText(WebViewActivity.this, R.string.auth_url_empty, 3000).show();  

  4. }  


如果直接寫在主線程中的話 在2.x 版本中還是能運行 但是在4.0以後就會出現錯誤。


7797295

spacer.gif
spacer.gif
spacer.gif
1343471944_7739.jpg


網上也有很多相關資料比如說在主線程中添加

  1. // 詳見StrictMode文檔

  2. StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder()  

  3.        .detectDiskReads()  

  4.        .detectDiskWrites()  

  5.        .detectNetwork()   // or .detectAll() for all detectable problems

  6.        .penaltyLog()  

  7.        .build());  

  8. StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder()  

  9.        .detectLeakedSqlLiteObjects()  

  10.        .detectLeakedClosableObjects()  

  11.        .penaltyLog()  

  12.        .penaltyDeath()  

  13.        .build());  


但是


.detectLeakedClosableObjects()  會報錯,

7797295

1343472003_2131.jpg

也就是說這個方法不用,但是查看源碼發現其方法是公共的


  1. /**

  2.             * Detect when an {@link java.io.Closeable} or other

  3.             * object with a explict termination method is finalized

  4.             * without having been closed.

  5.             *

  6.             * <p>You always want to explicitly close such objects to

  7.             * avoid unnecessary resources leaks.

  8.             */

  9. public Builder detectLeakedClosableObjects() {  

  10. return enable(DETECT_VM_CLOSABLE_LEAKS);  

  11.            }  


這個我就有點搞不清楚怎麼回事,資歷尚淺還不會。哈哈。


所以我就用第二種方法 也就是多線程,異步加載的方式加載數據。

代碼如下:

在主函數中發送一個空的消息 :

  1. new Thread(){  

  2. @Override

  3. publicvoid run() {  

  4. // TODO Auto-generated method stub

  5. super.run();  

  6.                url = AuthUtil.getAuthorizationURL();  

  7. if (url == null) {  

  8.                    Toast.makeText(WebViewActivity.this, R.string.auth_url_empty, 3000).show();  

  9.                }  

  10.                handler.sendEmptyMessage(0);  

  11.            }  

  12.        }.start();  



在handler中接受到消息 作出相應的處理。

  1. private Handler handler = new Handler() {  

  2. publicvoid handleMessage(Message msg) {  

  3. switch (msg.what) {  

  4. case0:  

  5.                <span style="white-space:pre">  </span>load(url, webView);  

  6. break;  

  7.            }  

  8.        };  

  9.    };  


這樣就解決的這個異常。


有什麼不對的地方,請多指教。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章