可重入锁ReentrantLock,就是支持可重入的锁,它表示该锁能够支持一个线程对资源的重复加锁。
此外,ReentrantLock还支持获取锁时的公平和非公平性选择。
1.公平性锁和非公平性锁的区别
公平性锁:锁的获取顺序符合请求的绝对时间顺序(FIFO)。公平性锁每次都是从同步队列中的第一个节点获取到锁。
在tryAcquire方法中,需要判断同步队列中当前节点是否有前驱节点,如果有,表示有线程比当前线程更早地请求获取锁,因此需要等待前驱线程获取并释放锁之后才能继续获取锁。
非公平性锁:ReentrantLock默认为非公平性锁。非公平性锁虽然可能造成线程饥饿,但极少的线程切换,保证了其更大的吞吐量。