Lock锁之公平锁/非公平锁
Java中的公平锁和非公平锁是什么?二者区别?
公平锁:多线程高并发情况下,线程获得锁的顺序是先到先得,依次获得
非公平锁:线程获得锁的顺序是先抢先得,先运行的线程不一定先获得锁,允许加塞,所以结果是不公平的
二者区别:公平锁先到先得,非公平锁先抢先得,非公平锁比公平锁的吞吐量会大一些。
ReentrantLock和snychronized是什么锁?
ReentrantLock默认是非公平锁
Lock lock = new ReentrantLock();
snychronized也是非公平锁
编写一个公平锁的实例:
package cas;
import java.util.concurrent.locks.ReentrantLock;
/**
* 公平锁实例
*
*/
public class LockTest {
private ReentrantLock lock;
//有参构造,根据传入布尔值类型,new一个公平锁或者非公平锁
public LockTest(boolean isFair){
lock = new ReentrantLock(isFair);
}
public void ThreadGetLockMethod(){
try{
lock.lock();
//当前线程获得锁资源
System.out.println(Thread.currentThread().getName()+"\t getLock");
}finally{
lock.unlock();
}
}
public static void main(String[] args){
LockTest lock = new LockTest(true);//传入值为true,new一个公平锁
Runnable runnable = new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName()+"\t thread run");
lock.ThreadGetLockMethod();
}
};
for(int i=1;i<=10;i++){
new Thread(runnable).start();
}
}
}
运行结果:
由此可见:线程的run的先后顺序和getLock的顺序是一致的,锁资源先到先得
非公平锁的实例:
运行效果:
由此可见:线程run的顺序和getLock的顺序是不一致的,锁资源并非先到先得,而是先抢先得