Maison > Questions et réponses > le corps du texte
新手问个简单的问题:
为什么以下代码运行结果是这样的呢?
Thread-0出售票20
Thread-0出售票19
Thread-0出售票18
Thread-0出售票17
Thread-0出售票16
Thread-0出售票15
Thread-0出售票14
Thread-0出售票13
Thread-0出售票12
Thread-0出售票11
Thread-0出售票10
Thread-0出售票9
Thread-0出售票8
Thread-0出售票7
Thread-0出售票6
Thread-0出售票5
Thread-0出售票4
Thread-0出售票3
Thread-0出售票2
Thread-0出售票1
public class ThreadDemo {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
TestThread t = new TestThread();
new Thread(t).start();
new Thread(t).start();
new Thread(t).start();
new Thread(t).start();
}
}
class TestThread implements Runnable {
private int tickets = 20;
public void run() {
while(true) {
if(tickets>0)
System.out.println(Thread.currentThread().getName()+"出售票"+tickets--);
}
}
}
黄舟2017-04-17 13:17:21
你多跑几次应该就不会这样了,如果你把system.out换成写到一个文件,那肯定会多线程输出。
应该和虚拟机的线程调度相关,如果在20次的循环次数执行完毕前第二个线程还没启动起来,当然只会有thread-0跑了,如果后续线程在20次运行结束之前启动,就会有多个线程输出了,你换成2000试试,肯定会有很多线程输出。
ringa_lee2017-04-17 13:17:21
public class ThreadDemo {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
new TestThread().start();
new TestThread().start();
new TestThread().start();
new TestThread().start();
}
}
class TestThread extends Thread {
private int tickets = 20;
public void run() {
while(true) {
if(tickets>0)
System.out.println(Thread.currentThread().getName()+"出售票"+tickets--);
else
break;
}
}
}