Java线程不会停止/中断

时间:2013-12-28 18:37:23

标签: java multithreading

我正在尝试终止一个线程,但它不会中断或停止。所有这些都是名为Webots的软件控制器的一部分。我用它来模拟一个多机器人系统。在每个机器人的控制器中,我启动一个通过机器人接收器接收消息的线程。该线程必须首先启动,并在模拟结束时终止。

此线程的run方法如下所示:

public void run() {
    while (true)
    {
        String M = recieveMessage();
        char[] chars = M.toCharArray();
        if(chars[0]==robotName||chars[0]=='0')
            messages.add(M);                                                
     }
}

在主控制器中,我的代码如下所示:

MessageThread MT = new MessageThread(messages, receiver,getName());
MT.start();
for (int i = 0; i < 100; i++)
{
    try
    {
         Thread.sleep(25);  } catch (InterruptedException e) {      e.printStackTrace();    }
    System.out.println(messages.get(messages.size()-1));                
 }
 MT.interrupt();//MT = null;
 System.out.println(MT.interrupted());

我在主控制器中的操作并不重要,所以不要判断它。例如,消息是一个ArrayList。它就像一个MT放入消息并且主线程读取的缓冲区。我使用它是因为接收器和发射器不同步。

如果我调用interrupt()或MT = null但中断()它返回false并且MT继续运行。我的代码有什么问题吗?

我读了一些话题,如:

http://docs.oracle.com/javase/1.5.0/docs/guide/misc/threadPrimitiveDeprecation.html

How do you kill a Thread in Java?

interrupt() doesn't work

Java: How interrupt/stop a thread?

等等,但我找不到任何有用的答案。

修改

谢谢大家,我已对代码进行了更改。我将它添加到MessageThread类:

private volatile boolean isRunning = true;

然后我使用while(isRunning)代替while(true),我添加了

public void kill()
{
    isRunning = false;
}

并调用MT.kill()而不是MT.interrupt()

它工作但我无法找出interrupt()的错误。我读了@ExtremeCoders推荐的链接。但是,我仍然感到困惑。它说“一个线程必须支持它自己的中断”。那么我是否必须覆盖interrupt()方法?我不能调用中断来终止线程吗?

再次感谢。

1 个答案:

答案 0 :(得分:3)

中断线程只是在线程上设置了一个标志。如果线程从不检查标志,它将不响应。通过创建自己的boolean成员,您不必要地复制了该功能。

以下是您尝试做的一般模式:

@Override
public void run() {
  while(!Thread.interrupted() {
    /* Do something. */
  }
  Thread.currentThread().interrupt();
}

这样您就可以按预期调用MT.interrupt()。这比创建自己的标记和自定义方法更好:您可以将Runnable任务与ExecutorService等高级工具一起使用,取消将起作用,因为您使用了标准API;对于整个ThreadGroup的中断也是如此。

调用Thread.interrupted()清除线程的中断状态;我们通过调用Thread.currentThread().interrupt()来设置它,再次设置状态,以便run()的调用者可以检测到中断状态。然而,这可能并不总是可取的。