Java 公平锁与非公平锁
公平锁与非公平锁:
锁Lock分为公平锁和非公平锁。
公平锁:表示线程获取锁的顺序是按照加锁的顺序来分配的,及先来先得,先进先出的顺序。
非公平锁:表示获取锁的抢占机制,是随机获取锁的,和公平锁不一样的就是先来的不一定能拿到锁,
有可能一直拿不到锁,所以结果不公平。
公平锁实例:
public class Service {
private ReentrantLock lock;
public Service(boolean isFair) {
super();
lock = new ReentrantLock(isFair);
}
public void serviceMethod() {
try {
lock.lock();
System.out.println("ThreadName=" + Thread.currentThread().getName()
+ "获取锁定");
} finally {
lock.unlock();
}
}
public static void main(String[] args) {
final Service service = new Service(true);
Runnable runnable = new Runnable() {
@Override
public void run() {
System.out.println("★线程" + Thread.currentThread().getName()
+ "运行了");
service.serviceMethod();
}
};
Thread[] threadArray = new Thread[10];
for (int i = 0; i < 10; i++) {
threadArray[i] = new Thread(runnable);
}
for (int i = 0; i < 10; i++) {
threadArray[i].start();
}
}
}
下面看看非公平锁的实现:
非公平锁运行的结果是无序的,说明先start()启动的线程不代表先获得锁。
- 方法int getHoldCount()的作用是查询当前线程保持此锁定的个数,也就是调用lock()方法的次数。
- 方法int getQueueLength()的作用是返回正等待获取此锁定的线程估计数,比如有5个线程,1个线程首先执行await()方法,那么在调用
- getQueueLength()方法后返回值是,说明有4个线程同时在等待lock的释放。
- 方法int getWaitQueueLength(Condition condition)的作用是返回等待与此锁定相关的给定条件Condition的线程估计数,比如有5个线程,每个线程都执行了同一个condition对象的await()方法,则调用getWaitQueueLength(Condition condition)方法时返回的int值是5.
- 方法boolean hasQueuedThread(Thread thread)的作用是查询指定的线程是否正在等待获取此锁定。
- 方法boolean hasWaiters(Condition condition)的作用是查询是否有线程正在等待与此有关的condition条件。
- 方法boolean isFair()的作用是判断是不是公平锁。
在默认情况下,ReentrantLock类使用的是非公平锁。 - 方法boolean isHeldByCurrentThread()的作用是查询当前线程是否保持此锁定。
- 方法boolean isLocked()的作用是查询此锁定是否由任意线程保持。
- 方法void lockInterruptibly()的作用是:如果当前线程为被中断,则获取锁定,如果已经被中断则出现异常。
- 方法boolean tryLock()的作用是,仅在调用时锁定未被另一个线程保持的情况下,才获取锁定。
- 方法boolean tryLock(long timeout,TimeUnit unit)的作用是,如果锁定在给定等待时间内没有被另一个线程保持,且当前线程未被中断,则获取该锁定。