Thread多线程stopSleep顺序问题

时间:2021-08-09 06:31:07

今天呢,学习了javase多线程,里面的睡眠sleep问题有点困扰:

public class Thread_06_stopSleep{
public static void main(String[] args)throws Exception{
Processor p = new Processor();
Thread t = new Thread(p);
t.start();//
Thread.sleep();//Thread:代表了当前代码所在的类那个线程,main()
for(int i=; i < ; ++i){
System.out.println( Thread.currentThread().getName()+"----->" + i );
}
p.run = false;
}
} class Processor implements Runnable{
boolean run = true;
public void run(){
for(int i=; i < ; ++i){
if (run) {//如果run为假的话.sleep就不执行了
try{
Thread.sleep();
}catch(Exception e){
e.printStackTrace();
}
System.out.println( Thread.currentThread().getName()+"----->" + i );
}else{
System.out.println( "sleep,被唤醒了" );
return; //终止函数运行,这里也就是杀死当前线程
}
}
}

但是为什么输出完以后,为什么下面还有一次为真?效果图如下:

Thread多线程stopSleep顺序问题

为什么还有第五次,不是第五次的时候就已经将false传入了么,求高手指点迷津!!

对了,还有我因为也是初学,发的文章也没有什么技术含量,你们要转载就随便转,但是请把我的链接加上,OK?