Android:执行长任务时''threadid = 3:对信号3作出反应'

时间:2017-01-10 13:37:15

标签: android multithreading android-asynctask android-anr-dialog android-runonuithread

我正在我的应用程序中执行Runtime.getRuntime().exec(cmd)的命令。因为完成执行需要很长时间(几分钟),所以我把它放在一个线程中。但是通过线程方法,应用程序中途暂停,我看到了这条消息:

threadid=3: reacting to signal 3
Wrote stack traces to '/data/anr/traces.txt'

以下是我正在使用的代码:

Thread thread = new Thread() {
        public void run() {                
            Process process = Runtime.getRuntime().exec(cmd);
            //cmd : command to be executed
            process.waitFor();

        }
    };
    thread.start();
    thread.join();

我在这里缺少什么?如何防止我的应用因处理时间过长而被暂停?

注意:我知道还有其他方法,如AsyncTask等,但我认为在这种情况下它不会有任何不同。 (或者会吗?)

1 个答案:

答案 0 :(得分:0)

您的应用正在此行上引起ANR:thread.join()。该调用导致当前线程在继续执行之前等待另一个线程死亡。如果在主线程上调用此命令,而另一个线程花费的时间超过5秒才能继续,则将导致ANR。根据您要执行的操作,最好不要在线程上调用join,而在线程即将完成时调用观察者。

有关如何实现观察者的示例,请参见http://stackoverflow.com/questions/994840/how-to-create-our-own-listener-interface-in-android