多线程执行顺序

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只能结束当前线程,并不能结束整个程序。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值