class Ticked implements Runnable{
private int num=100;
public void run()
{
while(true)
{
if(num>0)
{
System.out.println(Thread.currentThread().getName()+" : "+(num--));
}
}
}
}
class Dream{
public static void main(String[] args)
{
Ticked t=new Ticked();
Thread t1=new Thread(t);
Thread t2=new Thread(t);
t1.start();
t2.start();
}
}
程序结果:
Thread .......
Thread-1 : 9
Thread-1 : 8
Thread-1 : 7
Thread-1 : 6
Thread-1 : 5
Thread-1 : 4
Thread-1 : 3
Thread-1 : 2
Thread-1 : 1
Thread-0 : 15
为什么thread-0 在最后输出15呢?不是应该按顺序计算吗?既然num--已经计算的15,就会直接输出才对,所以整个输出都是,15,14,13,这样一直减下去才对吧?num都已经计算到0了,输出15说明已经计算完成但是没有输出,开始计算和输出是同一个语句,不是该一起执行吗?