为什么在doInBackground()中调用Thread.sleep会使应用程序崩溃?

时间:2016-11-23 05:23:00

标签: android multithreading android-asynctask

我使用AsyncTask从我的firebase中提取数据并且它可以工作,但我使用空的while循环来确保我的数据库在任务移动到下一个之前完成它的操作步。我知道在c中使用空的while循环会增加CPU使用率,而且通常是非常糟糕的做法。但是,当我尝试做我在c中做的事情(呼叫睡眠或等待)时程序崩溃。还有其他方法可以为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

以下是错误

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) 

1 个答案:

答案 0 :(得分:2)

使用倒数计时器

 CountDownTimer test=  new CountDownTimer(3000,1000) {

        @Override
        public void onTick(long millisUntilFinished) {
            // do when countdown timer is started like show progressbar

        }

        @Override
        public void onFinish() {

            //write what ever you want to do after completing time like hiding progress bar
        }
    };


    test.start();

这里是1000是开始时间,3000是结束时间,以ms为单位