Gson Android和Async任务

时间:2013-05-15 19:59:49

标签: java android

所以我不久前有一个关于GSON的问题,现在我被告知要使用一个名为AsyncTask的东西

尽管关于如何使用它的描述非常简短AsyncTask Doc

我设法让它起作用了。

这是我的Async类:

public class JsonCollector extends AsyncTask<URL, integer, String> {
private String finalString;
public JsonCollector(){

}
public String test(){
    URL url = null;
    try {
        url = new URL("http://api.heroesofnewerth.com/player_statistics/ranked/nickname/Hieratic/?token=0CZGH8ZI7UR8J2GN");
    } catch (MalformedURLException e1) {
        // TODO Auto-generated catch block
        e1.printStackTrace();
    }
    BufferedReader reader = null;
    String x = "";
    try {
        reader = new BufferedReader(new InputStreamReader(url.openStream(), "UTF-8"));
        for (String line; (line = reader.readLine()) != null;) {
            System.out.println(line);
            x = line;
        }
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } finally{
        if (reader !=null) try{reader.close();} catch (IOException ignore) {
        }{}
    }
    this.finalString = x;
    return x;
}
@Override
protected String doInBackground(URL... params) {
    JsonElement root = new JsonParser().parse(test());

    finalString = root.getAsJsonObject().get("rnk_wins").toString();
    return "";
}
public String getFinalString(){
    return finalString;
}

}

现在这可以很好地解决我得到GSON错误:

  05-15 19:51:05.091: E/AndroidRuntime(1832): FATAL EXCEPTION: AsyncTask #1
05-15 19:51:05.091: E/AndroidRuntime(1832): java.lang.RuntimeException: An error occured while executing doInBackground()
05-15 19:51:05.091: E/AndroidRuntime(1832):     at android.os.AsyncTask$3.done(AsyncTask.java:299)
05-15 19:51:05.091: E/AndroidRuntime(1832):     at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:352)
05-15 19:51:05.091: E/AndroidRuntime(1832):     at java.util.concurrent.FutureTask.setException(FutureTask.java:219)
05-15 19:51:05.091: E/AndroidRuntime(1832):     at java.util.concurrent.FutureTask.run(FutureTask.java:239)
05-15 19:51:05.091: E/AndroidRuntime(1832):     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
05-15 19:51:05.091: E/AndroidRuntime(1832):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
05-15 19:51:05.091: E/AndroidRuntime(1832):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
05-15 19:51:05.091: E/AndroidRuntime(1832):     at java.lang.Thread.run(Thread.java:856)
05-15 19:51:05.091: E/AndroidRuntime(1832): Caused by: java.lang.NoClassDefFoundError: com.google.gson.JsonParser
05-15 19:51:05.091: E/AndroidRuntime(1832):     at logic.JsonCollector.doInBackground(JsonCollector.java:47)
05-15 19:51:05.091: E/AndroidRuntime(1832):     at logic.JsonCollector.doInBackground(JsonCollector.java:1)
05-15 19:51:05.091: E/AndroidRuntime(1832):     at android.os.AsyncTask$2.call(AsyncTask.java:287)
05-15 19:51:05.091: E/AndroidRuntime(1832):     at java.util.concurrent.FutureTask.run(FutureTask.java:234)
05-15 19:51:05.091: E/AndroidRuntime(1832):     ... 4 more

请注意我已将lib添加到我的项目中:

enter image description here

任何人都可以告诉我为什么我的课程没有找到execption吗?

1 个答案:

答案 0 :(得分:2)

您在Referenced Libraries库下拥有它的事实是您的问题。

您需要做的是在项目文件夹中创建\libs并将jar文件放在那里。

这将导致将此库放在项目的Android Dependecies文件夹下(您可能需要清除项目/关闭并重新打开Eclipse)。

<强>更新

此屏幕截图应说明,您应该将已使用的.jar文件放在项目中。

enter image description here