我正在尝试实现一个简单的问题,我有一个全局变量来出售门票。我产生了 3 个线程来出售 10 张门票,而我正在使用二进制信号量进行此操作。
private static int noOfTickets =10;
private static boolean soldAll = false;
private static Random r = new Random(10);
/************ MAIN **************/
public static void main(String[] arg){
// spawn 10 threads to see a tickets
for(int i =0; i<3; i++){
Thread t = new Thread(new sellRunnable());
t.setName("Me_"+i);
t.start();
}
}
/************ MAIN **************/
public static void sell() throws InterruptedException{
Semaphore b = new Semaphore(1);
int numOfTicketsSoldByThisThread = 0;
while(!soldAll){
addRandomDelay(1000, 100);
b.acquire();
if(noOfTickets>0){
Thread t = Thread.currentThread();
numOfTicketsSoldByThisThread++;
noOfTickets--;
System.out.println("I "+t.getName()+" sold "+numOfTicketsSoldByThisThread+"ticket. tickets left are "+noOfTickets);
}else{
soldAll = true;
System.out.println(" sold all tickets");
}
b.release();
}// end of while
}
public static class sellRunnable implements Runnable{
public void run() {
try {
sell();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
当我运行此代码时,我没有得到正确的输出,有时我会得到这个
- 我 Me_2 卖了 1 票。剩下的票是 7
- 我 Me_1 卖出了 1 张票。剩下的票是 7
注意,两个线程是如何打印出剩下的票是 7?这不可能吧?我知道 noOfTicketsLeft-- 不是原子操作,但它在信号量内部。那么,它应该工作吗?