java多线程初级新手问题

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说明已经计算完成但是没有输出,开始计算和输出是同一个语句,不是该一起执行吗?

这么说吧,你两个线程访问的是同一个线程对象,;
当其中一个线程在执行打印的那条语句的时候,另一线程也来读取了,所以就有可能出现另一个线程没有打印全,
你可以观察下,除了初始值100 可能相同,其它的值应该不会重复;

你可以试着加锁,或者线程同步

你也可以试着把打印的条件改下,if(num== 0 ) break;,你就明白了