我正在使用AsyncTask从Firebase中获取数据,它可以工作。但是,我正在使用一个空的while循环来确保我的数据库完成操作,然后任务才会进入下一步。我知道在C语言中使用空的while循环会增加CPU使用率,并且通常是非常糟糕的实践。然而,当我尝试做我在C语言中会做的事情(调用sleep或wait)时,程序会崩溃。在安卓中有其他方法可以实现这一点吗?
protected String doInBackground(String... params) {
// add a local list of the restaurants found at yelp and a reference for the background thread to process.
addRes(yelp.getRestaurants());
// loop through each restaurant and add all the menu items from each one. I think we need to randomize this list later on to provide variety in the app.
for (int i = 0; i < restNames.size(); i++) {
firebase = new firebaseHandler("Tastr Items/" + restNames.get(i) + "/Menu");
System.err.println("Adding Menu Item From ----> " + restNames.get(i));
firebase.readFromDatabase();
// Wait for firebase to finish adding new data, I would like to call sleep() here but it crashes the app for some reason.
while (!firebase.isReaderDone()) {
// Here his where I want to call sleep until firebase Handler is finished.
try {
wait(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
// second loop to run through each menu item at each restaurant, this would be very inefficient for a huge number, but for now it should be fine if we have less than 100 or so menu items per restaurant.
for (int j = 0; j < firebase.getReaderList().size(); j++) {
System.err.println("Adding Menu Item ----> " + firebase.getReaderList().get(j));
addMenuItem(firebase.getReaderList().get(j));
firebase.changeReference("Tastr Items/" + restNames.get(i) + "/Menu/" + firebase.getReaderList().get(j) + "/Image Path");
}
}
return null;
}//doInBackground
这里是错误信息
E/AndroidRuntime: FATAL EXCEPTION: AsyncTask #2
Process: com.smileyface.tastr, PID: 5863
java.lang.RuntimeException: An error occurred while executing doInBackground()
at android.os.AsyncTask$3.done(AsyncTask.java:325)
at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:354)
at java.util.concurrent.FutureTask.setException(FutureTask.java:223)
at java.util.concurrent.FutureTask.run(FutureTask.java:242)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:243)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
at java.lang.Thread.run(Thread.java:761)
Caused by: java.lang.IllegalMonitorStateException: object not locked by thread before wait()
at java.lang.Object.wait(Native Method)
at com.smileyface.tastr.Activities.TouchActivity$dataLoader.doInBackground(TouchActivity.java:369)
at com.smileyface.tastr.Activities.TouchActivity$dataLoader.doInBackground(TouchActivity.java:346)
at android.os.AsyncTask$2.call(AsyncTask.java:305)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:243)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
at java.lang.Thread.run(Thread.java:761)