线程多次调用start方法,引发的异常

简单的线程使用,大家应该都会使用,下面的这个问题,不知道大家有没有注意过。

public class Test146 {
    public static void main(String[] args) {
        MyThread11 m = new MyThread11();
        for(int i = 0;i<5;i++) {
            m.start();
        }

    }
}

class MyThread11 extends Thread{
          @Override
        public void run() {
            // TODO Auto-generated method stub
            super.run();
            System.out.println("我是线程任务");
        }
}

运行结果如下:

线程多次调用start方法,引发的异常_第1张图片

接下来,我们就要看这个异常是如何产生的。网上对此解释,说是在循环的时候,共用了一个Thread对象。可是为什么共用了一个Thread对象,就引发错误了呢。

       private volatile int threadStatus = 0;
       A zero status value corresponds to state "NEW".
       if (threadStatus != 0)
            throw new IllegalThreadStateException();

我们都知道,线程的五种生命周期, 新建->就绪->运行->死亡->堵塞。在每次实例化的时候,会给这个threadStatus 为0,用volatile ,可以保证该变量的可见性。在不同的生命周期,值会变,而在start方法通过判断,就可以知道执行的线程是不是一个新的线程实例。

由上面的,我们可以看出如果我们保证每次都使用的不是同一个Thread实例,就可以解决上面的问题。我们试试创建线程的另一个方法,实现runnable。每一个任务都是包装在一个Thread实例中,所以,执行循环任务,不会出现上述的问题。

代码如下:

        Thread t;
        for(int i = 0;i<5;i++) {
         t = new Thread(new MyTask11());//MyTask11内容和MyThread11一致,就是它是通过implement实现Thread,不是继承。
         t.start();

你可能感兴趣的:(java,java,多线程)