少しロック、大きな質問?疑いをロックしますか?

ロックする

使い方 次のロックをより適切にするには、誰でもチケットを購入できますか?

同期と比較した場合のメリットは?

ロックの使用法の仕様が最終的に試行されます

private final ReentrantLock lock = new ReentrantLock(); //この定義の利点は?

import java.util.concurrent.locks.ReentrantLock;
public class TestLock {//这样李白会一个人拿完所有的票
    public static void main(String[] args) {
        TestLock1 testLock1 = new TestLock1();
        Thread t1 = new Thread(testLock1,"李白");
        Thread t2 = new Thread(testLock1,"杜甫");
        Thread t3 = new Thread(testLock1,"秦始皇");
        t1.start();
        t2.start();
        t3.start();
    }
}
class TestLock1 implements Runnable{
    private int ticketNum = 10;
    private final ReentrantLock lock = new ReentrantLock();
    @Override
    public void run() {
        while (true){
            try{//规范?
                lock.lock();//上锁,与ticketNum有关的代码,但是能不能再缩小范围呢?
                if(ticketNum>0){
                    try {
                        Thread.sleep(1000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println("剩余票数"+ticketNum--);
                }else{
                    break;
                }
            }finally {
                lock.unlock();//解锁
            }
        }
    }
}

おすすめ

転載: www.cnblogs.com/li33/p/12722058.html