import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
/**
* @Author: yangpeng
* @ClassName: 测试类
* @Description: 演示多线程抢票问题
* @Date: 2020/6/28 15:46
* @Version v1.0
*/
public class Test {
/**
* 剩余票数
*/
public int ticket = 1000;
/**
* 锁
*/
private Lock lock = new ReentrantLock();
public static void main(String[] args) {
new Test().sell();
}
public void sell() {
new Thread(()-> {
lockSell();
},"检票口1").start();
new Thread(()-> {
lockSell();
},"检票口2").start();
new Thread(()-> {
lockSell();
},"检票口3").start();
new Thread(()-> {
lockSell();
},"检票口4").start();
}
private void lockSell() {
while (true) {
lock.lock();
try {
if (ticket > 0) {
ticket--;
System.out.println(Thread.currentThread().getName() + "卖出一张票,还剩" + ticket + "张票");
Thread.sleep(100);
} else {
break;
}
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
}
}