I'm using AsyncTask to pull data from my firebase and it works, however I'm using an empty while loop to ensure my database finishes it's operation before the Task moves on to the next step. I know in c using an empty while loop drives up CPU usage, and is generally really bad practice. However, when I try to do what I would do in c (call sleep or wait) the program crashes. Is there another way to do this for Android?
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
Here are the errors
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)