您的位置:首页 > 移动开发 > Android开发

android.os.NetworkOnMainThreadException异常

2014-02-12 21:09 330 查看
今天遇到一个问题,由于自己在activity主线程写了一个访问网络的方法,一直都可以用,但是今天不小心改了下manifest.xml中的警告设置了SDK的目标版本,出现了这个异常,最开始很纳闷,后来仔细检查了下发现是这个问题,因此采用了偷懒的解决方法,去掉了targetSdkVersion这个设置,运行正常了!其实这个异常意思是在主线程访问网络时出的异常。
Android在4.0之前的版本 支持在主线程中访问网络,但是在4.0以后对这部分程序进行了优化,也就是说访问网络的代码不能写在主线程中了。

解决办法一:
在manifest.xml中把targetSdkVersion这个去掉(偷懒方法);
解决办法二(转载的,地址:http://blog.csdn.net/wotoumingzxy/article/details/7797295):
那么如何做才能正常运行呢? 请看这里:

例如:  从网络中获取一个Url地址。 

[java] view
plaincopyprint?

url = AuthUtil.getAuthorizationURL();  

if (url == null) {  

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

}  

如果直接写在主线程中的话 在2.x 版本中还是能运行 但是在4.0以后就会出现错误。





网上也有很多相关资料比如说在主线程中添加

[java] view
plaincopyprint?

// 详见StrictMode文档  

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

        .detectDiskReads()  

        .detectDiskWrites()  

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

        .penaltyLog()  

        .build());  

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

        .detectLeakedSqlLiteObjects()  

        .detectLeakedClosableObjects()  

        .penaltyLog()  

        .penaltyDeath()  

        .build());  

但是

.detectLeakedClosableObjects()  会报错, 





也就是说这个方法不用,但是查看源码发现其方法是公共的

[java] view
plaincopyprint?

/** 

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

             * object with a explict termination method is finalized 

             * without having been closed. 

             * 

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

             * avoid unnecessary resources leaks. 

             */  

            public Builder detectLeakedClosableObjects() {  

                return enable(DETECT_VM_CLOSABLE_LEAKS);  

            }  

这个我就有点搞不清楚怎么回事,资历尚浅还不会。哈哈。

所以我就用第二种方法 也就是多线程,异步加载的方式加载数据。

代码如下:

在主函数中发送一个空的消息 :

[java] view
plaincopyprint?

new Thread(){  

            @Override  

            public void run() {  

                // TODO Auto-generated method stub  

                super.run();  

                url = AuthUtil.getAuthorizationURL();  

                if (url == null) {  

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

                }  

                handler.sendEmptyMessage(0);  

            }  

        }.start();  

在handler中接受到消息 作出相应的处理。

[java] view
plaincopyprint?

private Handler handler = new Handler() {  

  

        public void handleMessage(Message msg) {  

            switch (msg.what) {  

                case 0:  

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

                    break;  

            }  

        };  

    };  

这样就解决的这个异常。

有什么不对的地方,请多指教。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: