日期:2014-05-20  浏览次数:20629 次

这个线程为何没有交替输出
package L1602;

public class TestThread2 {

/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Runner2 r = new Runner2();
Thread t1 = new Thread(r);
Thread t2 = new Thread(r);
t1.setName("线程1");
t2.setName("线程2");
t1.start();
t2.start();
}
}

class Runner2 implements Runnable {
public void run() {
for (int i = 0; i < 20; i++) {
String s = Thread.currentThread().getName();// 获得当前对象的名称
System.out.println(s + ":" + i);
}
}
}

我看视频上是交替输出两个线程,但我运行时是显示完线程1后再显示线程2,为何没有交替输出?

------解决方案--------------------
线程运行本身就有不确定性
------解决方案--------------------
t1 t2的级别一样,
运行结果不确定的,
你可以试下在循环里sleep()下!
------解决方案--------------------
探讨
线程运行本身就有不确定性

------解决方案--------------------
你设定的循环时间太小了,设大点会看出来,
------解决方案--------------------
探讨
t1 t2的级别一样,
运行结果不确定的,
你可以试下在循环里sleep()下!