让 java 等到变量改变

make java wait until variable changes

我想让我的代码等到 class 中的任何地方对变量 finaloutcomes 进行更改。有什么办法吗?我在下面发布的 Asynctask 中执行此操作。

 public HashMap<String,String> checkbetoutcome() {

    new LoadAllGamet().execute();

    // INSERT CODE HERE

    return finaloutcomes;

}

异步任务

class LoadAllGamet extends AsyncTask<String, String, String> {
        @Override
        protected void onPreExecute() {
            super.onPreExecute();

        }

        protected String doInBackground(String... args) {
           // HttpParams httpParameters = new BasicHttpParams();
           // HttpConnectionParams.setConnectionTimeout(httpParameters, 250000);
            //HttpConnectionParams.setSoTimeout(httpParameters, 250000);
            HttpClient client = new DefaultHttpClient();
            HttpPost post = new HttpPost(url_check_bet);
            List<NameValuePair> params = new ArrayList<NameValuePair>();
            params.add(new BasicNameValuePair("param", bet));
           // Log.d("CURRENTITEM", currentitem);
            try {
                post.setEntity(new UrlEncodedFormEntity(params));
            } catch (IOException ioe) {
                ioe.printStackTrace();
            }
            try {
                HttpResponse response = client.execute(post);
                Log.d("Http Post Responsecxxx:", response.toString());
                HttpEntity httpEntity = response.getEntity();
                InputStream is = httpEntity.getContent();
                JSONObject jObj = null;
                String json = "";
                client.getConnectionManager().closeExpiredConnections();
                try {
                    BufferedReader reader = new BufferedReader(new InputStreamReader(
                            is, "iso-8859-1"), 8);
                    StringBuilder sb = new StringBuilder();
                    String line = null;
                    while ((line = reader.readLine()) != null) {

                        if (!line.startsWith("<", 0)) {
                            if (!line.startsWith("(", 0)) {
                                sb.append(line + "\n");
                            }
                        }
                    }

                    is.close();
                    json = sb.toString();

                    json = json.substring(json.indexOf('{'));
                //    Log.d("sbsssssssssss", json);
                    try {
                        jObj = new JSONObject(json);
                    } catch (JSONException e) {
                        Log.e("JSON Parser", "Error parsing data " + e.toString());
                    }
                    allgames = jObj.getJSONArray("bets");
                 //   Log.d("WHAT IS MY ARRAY?", allgames.toString());

                       for (Integer i = 0; i < allgames.length(); i++) {
                           HashMap<String,String> statuses = new HashMap<>();
                            JSONObject c = allgames.getJSONObject(i);
                            JSONArray currentbet = c.getJSONArray("bet");
                            Log.d("Single array",currentbet.toString());

                           //  Storing each json item in variable

                           for (Integer a = 0; a < currentbet.length();a++) {
                               JSONObject d = currentbet.getJSONObject(a);
                            String Result = d.getString("Result");
                               String id = d.getString("gid");
                            Log.d("RESULTS",Result);

                           statuses.put(id, Result);
                        }
                           allbetsmap.add(i, statuses);
                           Log.d("ddd", statuses.toString());
                           Log.d("AAA", allbetsmap.get(i).toString());


                       }



                    } catch (Exception e) {
                        Log.e("Buffer Error", "Error converting result " + e.toString());
                    }


                }
             catch (IOException e) {
                e.printStackTrace();
            }




            return "";
        }



        @Override
        protected void onPostExecute(String param) {
            Log.d("SIZE",Integer.toString(allbetsmap.size()));
            //ArrayList<Map<String,String>> allbetsmap = new ArrayList<>();
            //ArrayList<Map<String,String>> passtocheck = new ArrayList<>();

            if (allbetsmap.size() == passtocheck.size()) {
                for (int i = 0; i < allbetsmap.size();i++) {
                if (allbetsmap.get(i).size() == passtocheck.get(i).size()) {
                    String finaloutcome = "won";
                    for (String a : allbetsmap.get(i).keySet()) {
                        String f = allbetsmap.get(i).get(a);
                        if(f.equals("null")) {
                            finaloutcome = "open";
                        }
                        else if (! (f.equals(passtocheck.get(i).get(a)))) {
                            finaloutcome = "lost";
                            break;
                        }
                    }
                    finaloutcomes.put(Integer.toString(i),finaloutcome);
                }
                }

            }
            Log.d("Vital",finaloutcomes.toString());


        }


    }

好吧,忘了我之前写的。我没有意识到您正在为 android 编写代码。这是 LoadAllGamet 的改进版本。这里有两件重要的事情。 1. 尽可能多地在本地定义,即在方法内部定义,或者 - 如果不可能 - 在 class 内部定义。 2. return 结果而不是将其放入某个变量。

class LoadAllGamet extends AsyncTask<String, Void, HashMap<String,String>> {
    protected HashMap<String,String> doInBackground(String ... args) {
        HashMap<String,String> finaloutcomes = new HashMap<>(),
        HashMap<Integer, HashMap<String,String>> allbetsmap = new HashMap<>();

        HttpClient client = new DefaultHttpClient();
        ...
        Log.d("SIZE",Integer.toString(allbetsmap.size()));
        if (allbetsmap.size() == passtocheck.size()) {
          ...
        }
        Log.d("Vital",finaloutcomes.toString());
        return finaloutcomes;
    }
}

每当你想做一些可能需要一些时间的事情时,你不应该 运行 在你应用程序的 UI 线程中,因为它可以阻止你的 UI。 相反 运行 它是异步的。一种方法是使用 AsyncTask。 假设您想做某事并且正在处理某事 您还想不时更新 UI(例如进度条)。一旦你 完成后您想对结果做其他事情。 这是一种写法。

void doSomething() {
  new AsyncTask<String, Progress, Result>() {
    protected Result doInBackground(String... args) {
      //some code
      publishProgress(values);
      //some more code
      return result;
    }

    protected void onProgressUpdate(Progress ... values) {
      updateProgessBars(values);
    }

    protected void onPostExecute(Result result) {
      doSomethingElse(result);
    }
  }.execute();
}

new AsyncTask<String, Progress, Result>中的StringdoInBackground 的参数。然而,通常你并不真正需要它,除非 你想将参数传递给 executeProgress 是您要发送到 onProgressUpdate 的值的类型。那 如果你想在后台处理时更新你的 UI,你只需要一个 还在继续。 Result 当然是你的结果类型。无论你想在之后发生什么 doInBackground 写完了 onPostExecute.