多线程加lock锁后为什么每次执行的都是同一个线程

//这个多线程加上lock锁后为什么只有线程a在执行???
public class LockTest {
    public static void main(String[] args) {
        TestLock2 testLock2 = new TestLock2();
        new Thread(testLock2,"a").start();
        new Thread(testLock2,"b").start();
        new Thread(testLock2,"c").start();
    }
}
//多线程对象
class TestLock2 implements Runnable{
    int ticketNums = 10;
    private final ReentrantLock lock = new ReentrantLock();
    @Override
    public void run() {
        while (true){
            try {
                lock.lock();
                if(ticketNums > 0){
                    try {
                        Thread.sleep(3000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println(ticketNums--);
                    System.out.println(Thread.currentThread().getName());
                }else {
                    break;
                }
            }finally {
                lock.unlock();
            }
        }
    }
}

下面是控制台的输出: 

这个就是ReentrantLock的特性呀 默认是非公平的 第一次获取锁的对象 第二次获取的概率比较大。 你多执行几次 或者改成公平锁。

或者让出时间片Thread.yield();

你可以多试几次 , unlock和lock之间时间间隔太小了, 所以大概率是拿到锁的那个线程会一直拿到锁, 不过还是有概率其他线程能拿到锁的 , 你把睡眠的代码放到 unlock 下面就能看到锁一直在被抢

删除

删除

删除

你在释放锁后睡会会。。让另外的2个线程能抢占到锁就能出现了