多线程卖票,期望的结果
条件
一.线程共享
线程之间不冲突礼让
二.抢到的票数递增
抢到的票数加一,到一定的数额停止
三.剩余票数递减
剩余的票数减一,减到零停止
代码
图片
输出
类
代码
输出
package 多线程卖票;
public class test {
public static void main(String[] args) {
//实例化
Thread t1 = new TicketThread();
t1.setName("黄牛党");
Thread t2 = new TicketThread();
t2.setName("抢票代理");
Thread t3 = new TicketThread();
t3.setName("桃跑跑");
t1.setPriority(Thread.MAX_PRIORITY);
t2.setPriority(Thread.MAX_PRIORITY);
t3.setPriority(Thread.MAX_PRIORITY);
//输出
t1.start();
t2.start();
t3.start();
}
}
类
package 多线程卖票;
public class TicketThread extends Thread{
static int num = 10;
static int sum = 0;
@Override
public void run() {
while (num>=0){
if (num==0){
System.out.println("票出售为空请下次再来!!!");
break;
}else {
num--;
while (sum<=10){
sum++;
String con = String.format("%s抢到了第%s张票,剩余%s",Thread.currentThread().getName(),sum,num);
System.out.println(con);
break;
}
}
}
}
}
结果