import javax.swing.*;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class salutionSoldTickets2 implements Runnable {
private int tickets=100;
Lock lock=new ReentrantLock();
//模拟买票
@Override
public void run() {
while (true){
//在会出现安全问题的代码前,上锁
lock.lock();
if (tickets>0){
//提高安全问题出现的概率,让程序睡眠一下
try{
Thread.sleep(10);
System.out.println("tickets:"+tickets);
tickets--;
} catch (InterruptedException e) {
e.printStackTrace();
}finally {
//代码后,释放锁
lock.unlock();
}
}else {
break;
}
if (tickets==0){
break;
}
}
}
}
小弟不才,因为鄙人用的是.net,粗略的看了下,当tickets==0的时候,进入后,lock是没有开锁的,
你这个代码,锁加的有点奇怪,因为在你的这个逻辑里面run()函数都是被独立的线程执行,不存在资源竞争的问题.
如果你的run函数调用了其它独立对象的某个函数,如果需要锁,你应该加在那个函数里面才对.
因为每个线程空间里面的对象直接进行互相调用是不会产生竞争关系,因为都是顺序执行的.
只有跨线程调用才会产生竞争关系.
在else if判断的时候开锁,解决问题
要不转行吧