今天在项目中遇到一个需要控制网络加载超时的情况,就是用AsyncTask的线程在后台加载网络资源,但是有时候需要处理网络状态非常差,造成线程假死的情况。我们都知道一个AsyncTask线程只能启动一次,线程结束之后对象就被回收了,而且是不能手动停止的。
解决办法是在请求网络的URL中控制延时时间:
这样当网络出现异常或长时间加载无果时,会提前强制结束AsyncTask线程
因为经常需要使用到,当个笔记写下来。。 :)
解决办法是在请求网络的URL中控制延时时间:
URL url = new URL(path);
HttpURLConnection connect = (HttpURLConnection)url.openConnection();
//设置连接服务器超时时间
connect.setConnectTimeout(60*1000);
//设置从服务器读取数据超时时间
connect.setReadTimeout(60*1000);
这样当网络出现异常或长时间加载无果时,会提前强制结束AsyncTask线程
因为经常需要使用到,当个笔记写下来。。 :)
本文介绍了一种在使用AsyncTask进行网络资源加载时如何处理超时问题的方法。通过设置HttpURLConnection的连接超时时间和读取超时时间,可以有效避免因网络状态不佳导致的线程假死现象。
485

被折叠的 条评论
为什么被折叠?



