ReentrantLock(true)为什么公平锁仍然会出现一个线程连续获得锁的情况?

ReentrantLock(true)为什么公平锁仍然会出现一个线程连续获得锁的情况?

 public class LockFairTest implements Runnable{
    //创建公平锁
    private static ReentrantLock lock=new ReentrantLock(true);
    public void run() {
        while(true){
            lock.lock();
            try{
                System.out.println(Thread.currentThread().getName()+"获得锁");
            }finally{
                lock.unlock();
            }
        }
    }
    public static void main(String[] args) {
        LockFairTest lft=new LockFairTest();
        Thread th1=new Thread(lft);
        Thread th2=new Thread(lft);
        th1.start();
        th2.start();
    }
}

Thread-1获得锁
Thread-1获得锁
Thread-1获得锁
Thread-1获得锁
Thread-1获得锁
Thread-1获得锁
Thread-1获得锁
Thread-1获得锁
Thread-1获得锁
Thread-0获得锁
Thread-1获得锁
Thread-0获得锁

线程调用start()之后并不是立刻开始执行run方法。他需要等待其他系统资源准备就绪。例如:CPU。
Thread0最开始可能没有获取到CPU时间,Thread1却获取到且跑了几次。