简单的线程使用,大家应该都会使用,下面的这个问题,不知道大家有没有注意过。
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("我是线程任务");
}
}
运行结果如下:
接下来,我们就要看这个异常是如何产生的。网上对此解释,说是在循环的时候,共用了一个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();