Android:我的异步任务正在ui线程上运行并拖延我的应用程序

时间:2017-01-19 17:14:55

标签: android api android-asynctask ui-thread

在我的应用中,我有两个异步任务,这两个任务都会进行API调用。

首先,asynctask1命中一个url端点,然后我解析出我需要用下一个(更强大的)asynctask命中的每个类别的页数。例如:我的第一个asynctask会给我一个看起来像

的数组
int[] arr = {1,5,12,40,1,0,40...,6}

所以基本上,这意味着我可以使用{上面的数组}两个不同的端点来获取我的数据。

这个数组然后转到我的asynctask2。 Asynctask2有两个for循环。外部forloop适用于每个类别(有26个类别,每个字母的1个类别)。内部for循环遍历类别的每个页面,根据上面该数组为该类别列出的页数。

我在asynctask2中制作了300个API调用。出于某种原因,这似乎在阻碍我的UI线程,即使它应该在后台运行。

下面是我的asynctask2代码(警告:接下来是丑陋的代码)

public class ItemDatabaseUpdater extends AsyncTask<ArrayList<Integer>, Void, ArrayList<Item>> {

private String apiRoute = "http://services.runescape.com/m=itemdb_oldschool/api/catalogue/items.json?category=1&alpha=";
private String apiLetter = "b";
private String apiRoutePage = "&page=";
private String apiPageNumber = "1";
private String data;
private ArrayList<Item> itemDB = new ArrayList<>();
private JSONParser jsonParser = new JSONParser();
private JSONArray jsonArray;
private String[] alphabet = {"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n",
        "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"};
private Item _item;

protected void onPreExecute() {}

protected ArrayList<Item> doInBackground(ArrayList<Integer>... args) {
    ArrayList<Integer> pageNumbersForEachLetter = getTotalPageCountForEachLetter(args[0]);
    for (int i=0; i<pageNumbersForEachLetter.size(); i++){
        apiLetter = alphabet[i];
        for (int j=1; j<pageNumbersForEachLetter.get((i))+1; j++){
            apiPageNumber = String.valueOf(j);
            try {
                String endRoute = apiRoute + apiLetter + apiRoutePage + apiPageNumber;
                URL url = new URL(endRoute);
                HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
                try {
                    BufferedReader br = new BufferedReader(new InputStreamReader(urlConnection.getInputStream()));
                    StringBuilder stringBuilder = new StringBuilder();
                    String dataEntry;
                    while ((dataEntry = br.readLine()) != null) {
                        stringBuilder.append(dataEntry).append("\n");
                    }
                    br.close();
                    data = stringBuilder.toString();

                    jsonArray = jsonParser.extractArrayFromObject(data, "items");
                    for(int k=0; k<jsonArray.length(); k++) {
                        JSONObject obj = jsonParser.extractObjectFromArray(jsonArray, k);
                        JSONObject currentDataObj = jsonParser.extractObjectFromObject(obj, "current");
                        JSONObject todayDataObj = jsonParser.extractObjectFromObject(obj, "today");
                        _item = new Item();
                        _item.setIconUrl(jsonParser.extractValueFromObject(obj,"icon"));
                        _item.setId(jsonParser.extractValueFromObject(obj,"id"));
                        _item.setName(jsonParser.extractValueFromObject(obj,"name"));
                        _item.setCurrentPrice(jsonParser.extractValueFromObject(currentDataObj,"price"));
                        _item.setPriceChangeToday(jsonParser.extractValueFromObject(todayDataObj,"price"));
                        _item.setTrendToday(jsonParser.extractValueFromObject(todayDataObj,"trend"));
                        itemDB.add(_item);
                    }
                }
                finally{
                    urlConnection.disconnect();
                }
            }
            catch (Exception e){return null;}
        }
    }
    return itemDB;
}

protected void onPostExecute(ArrayList<String> response) {}

private ArrayList<Integer> getTotalPageCountForEachLetter(ArrayList<Integer> arg){
    ArrayList<Integer> retArr = new ArrayList<>();
    for (int i : arg){
        retArr.add((int)(Math.ceil(i/12)));
    }
    return retArr;
}
}

根据请求,这是我调用我的asynctask2

的方式
try {itemDatabase = itemDatabaseUpdater.execute(itemCatagoryNumbers).get();} catch (Exception e){}

1 个答案:

答案 0 :(得分:2)

您正在dateTimeRange.getStartLocalDateTime().minusMinutes(dateTimeRange.getStartLocalDateTime().getMinute()%15)上致电get()。这表示“绑定当前线程直到任务完成”。由于您当前的线程是主应用程序线程,因此您阻止该线程,这完全消除了首先使用AsyncTask的价值。

删除AsyncTask来电。使用get()中任务的结果,该结果在主应用程序线程上调用,因此您可以安全地在那里更新UI。