public class MThread implements Runnable {
private int ticket = 1000;
{
System.out.println("总票数:1000张");
}
public void run() {
for (int i = 0;; i++) {
System.out.println(Thread.currentThread().getName()+"-----"+"i="+i);
try {
Thread.currentThread().sleep(30);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (this) {
if (ticket == 0)
return;
int sale = (int) (Math.random() * 10) + 1;
if (sale > ticket) {
sale = ticket;
ticket -= sale;
} else
ticket -= sale;
switch (Thread.currentThread().getName()) {
case "Thread-0":
System.out.println("A站出票" + sale + "张 余票:" + ticket + " i=" + i);
break;
case "Thread-1":
System.out.println("B站出票" + sale + "张 余票:" + ticket + " i=" + i);
break;
case "Thread-2":
System.out.println("C站出票" + sale + "张 余票:" + ticket + " i=" + i);
break;
case "Thread-3":
System.out.println("D站出票" + sale + "张 余票:" + ticket + " i=" + i);
break;
default:
break;
}
Thread.currentThread().yield();
}
}
}
public static void main(String[] args) {
MThread mt = new MThread();
Thread t1 = new Thread(mt);
Thread t2 = new Thread(mt);
Thread t3 = new Thread(mt);
Thread t4 = new Thread(mt);
t1.start();
t2.start();
t3.start();
t4.start();
}
}
输出结果:
总票数:1000张
Thread-0-----i=0
Thread-1-----i=0
Thread-2-----i=0
Thread-3-----i=0
B站出票7张 余票:993 i=0
Thread-1-----i=1
D站出票8张 余票:985 i=0
Thread-3-----i=1
C站出票5张 余票:980 i=0
Thread-2-----i=1
A站出票5张 余票:975 i=0
Thread-0-----i=1
B站出票5张 余票:970 i=1
Thread-1-----i=2
C站出票8张 余票:962 i=1
Thread-2-----i=2
D站出票5张 余票:957 i=1
Thread-3-----i=2
A站出票4张 余票:953 i=1
Thread-0-----i=2
B站出票10张 余票:943 i=2
Thread-1-----i=3
C站出票5张 余票:938 i=2
Thread-2-----i=3
A站出票4张 余票:934 i=2
Thread-0-----i=3
D站出票4张 余票:930 i=2
Thread-3-----i=3
B站出票4张 余票:926 i=3
Thread-1-----i=4
D站出票2张 余票:924 i=3
……
(1)当线程启动后,处于可运行状态,是否在运行取决于能否获得CPU的时间片;
(2)同步代码块之前,线程运行是乱序的,具有不确定性,获取锁的线程顺序执行,直到该线程释放锁;
(3)run方法中的return只能结束当前线程,并不能结束整个程序。