在client.execute(httpGet)上的doInBackground()行崩溃。为什么?

时间:2014-10-02 15:13:37

标签: java android multithreading crash thread-safety

崩溃是:java.lang.RuntimeException: An error occured while executing doInBackground()

为什么我在HttpResponse response = client.execute(httpGet);行遭遇崩溃?它与我的ThreadPolicy有关吗?​​

从我的片段中我称之为:

new ReadJSONFeedMainTask().execute(urlString);

....

private class ReadJSONFeedMainTask extends AsyncTask<String, Void, String> {
        protected String doInBackground(String... urls) {
            return Helper.readJSONFeed(urls[0]);
        }

        protected void onPostExecute(String result) {
         // do stuff
        }
    }
}

然后在这里打电话:

   public static String readJSONFeed(String URL) {

    ThreadPolicy tp = ThreadPolicy.LAX;
    StrictMode.setThreadPolicy(tp);

    String numberValue = URL.replaceAll(" ", "%20");

    StringBuilder stringBuilder = new StringBuilder();
    HttpClient client = new DefaultHttpClient();
    HttpGet httpGet = new HttpGet(numberValue);
    try {
        HttpResponse response = client.execute(httpGet);
        StatusLine statusLine = response.getStatusLine();
        int statusCode = statusLine.getStatusCode();
        if (statusCode == 200) {
            HttpEntity entity = response.getEntity();
            InputStream content = entity.getContent();
            BufferedReader reader = new BufferedReader(new InputStreamReader(content));
            String line;
            while ((line = reader.readLine()) != null) {
                stringBuilder.append(line);
            }
        } else {
            Log.e("JSON", "Failed to download file");
        }
    } catch (ClientProtocolException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }
    return stringBuilder.toString();
}

堆栈跟踪:

java.lang.RuntimeException: An error occured while executing doInBackground()
1   at android.os.AsyncTask$3.done(AsyncTask.java:299)
2   at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:352)
3   at java.util.concurrent.FutureTask.setException(FutureTask.java:219)
4   at java.util.concurrent.FutureTask.run(FutureTask.java:239)
5   at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
6   at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
7   at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
8   at java.lang.Thread.run(Thread.java:856)
9Caused by: com.splunk.mint.network.util.DelegationException: java.net.ConnectException: failed to connect to 50-89-72-86.res.bhn.net/50.89.72.86 (port 80): connect failed: ETIMEDOUT (Connection timed out)
10  at com.splunk.mint.network.util.Delegator.invoke0(Delegator.java:62)
11  at com.splunk.mint.network.util.Delegator.invoke(Delegator.java:45)
12  at com.splunk.mint.network.socket.MonitoringSocketImpl.connect(MonitoringSocketImpl.java:118)
13  at java.net.Socket.connect(Socket.java:842)
14  at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
15  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
16  at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
17  at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
18  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
19  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
20  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
21  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
22  at com.sortitapps.movies.Helper.readJSONFeed(Helper.java:1282)
23  at com.sortitapps.movies.MainFragment$ReadJSONFeedMainTask.doInBackground(MainFragment.java:680)
24  at com.sortitapps.movies.MainFragment$ReadJSONFeedMainTask.doInBackground(MainFragment.java:678)
25  at android.os.AsyncTask$2.call(AsyncTask.java:287)
26  at java.util.concurrent.FutureTask.run(FutureTask.java:234)
27  ... 4 more
28Caused by: java.net.ConnectException: failed to connect to 50-89-72-86.res.bhn.net/50.89.72.86 (port 80): connect failed: ETIMEDOUT (Connection timed out)
29  at libcore.io.IoBridge.connect(IoBridge.java:114)
30  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
31  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
32  at java.lang.reflect.Method.invokeNative(Native Method)
33  at java.lang.reflect.Method.invoke(Method.java:511)
34  at com.splunk.mint.network.util.Delegator.invoke0(Delegator.java:56)
35  ... 20 more
36Caused by: libcore.io.ErrnoException: connect failed: ETIMEDOUT (Connection timed out)
37  at libcore.io.Posix.connect(Native Method)
38  at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:85)
39  at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
40  at libcore.io.IoBridge.connect(IoBridge.java:112)

3 个答案:

答案 0 :(得分:6)

从BugSense更新到Splunk Mint后我遇到了同样的问题,我的代码没有任何问题。在我注释掉Splunk.init(...)方法调用之后,一切都开始重新开始了。问题出现在HTC设备上并且启用了Splunk Mint - 所有HttpClient#execute()方法的调用都抛出了DelegationException。不确定这是否是你的情况,但也许我的回答将帮助那些遇到与我相同问题的人。

答案 1 :(得分:1)

看起来非常清楚,堆栈跟踪的结尾表示Connection超时。您的服务器无法访问。

答案 2 :(得分:-2)

您应该将Asynctask用于服务器的任何工作,请参阅http://developer.android.com/reference/android/os/AsyncTask.html