-1

我正在像这样开始我的线程:

public void startTask(Runnable r)
{
    running = true;
    Log.i(tag, "-----------start.Runnable-----------");

    final Thread first = new Thread(r);
    currentTask = first;
    first.start();

    Thread second = new Thread(new Runnable() {

        @Override
        public void run() {
            try{
                first.join();
            }
            catch(InterruptedException e){

            }
            running = false;
        }
    });

    second.start();

}

当我想取消当前操作时,我正在根据这篇文章使用 Theread:http ://forward.com.au/javaProgramming/HowToStopAThread.html :

public void cancelTask()
{
    Log.i(tag, "-----------cancelTask()-----------");
    try{
        currentTask.interrupt();
        running = false;
    }
    catch(SecurityException e){
        e.printStackTrace();
    }
}

cancelTask​​ 后应用程序仍在运行,但我有异常:

12-05 20:29:00.274: W/System.err(13533): java.lang.InterruptedException
12-05 20:29:00.274: W/System.err(13533):    at java.lang.VMThread.sleep(Native Method)
12-05 20:29:00.294: W/System.err(13533):    at java.lang.Thread.sleep(Thread.java:1047)
12-05 20:29:00.294: W/System.err(13533):    at java.util.concurrent.TimeUnit.sleep(TimeUnit.java:331)
12-05 20:29:00.304: W/System.err(13533):    at com.rsd.myfirstapp3.ProgressServiceActivity$2.run(ProgressServiceActivity.java:174)
12-05 20:29:00.314: W/System.err(13533):    at java.lang.Thread.run(Thread.java:864)

.

在使用线程的此类操作中是正常的异常吗?

4

1 回答 1

0

线程自行停止或被外部进程停止。意味着一个线程在完成它正在做的任何事情之后完成它的执行,此时不会抛出 InterruptedException(这是显而易见的)。但是父线程(启动线程的线程)可能希望在其执行之间停止正在执行的线程,在这种情况下,抛出异常 InterruptedException 并且该异常被线程接收。这主要是因为当它被外部进程/父线程停止时,这个线程想要做一些事情(清理资源,关闭 IO 等)。参考

于 2016-11-29T03:43:40.067 回答