公平所:线程按照实现定义好的顺序执行,保证执行顺序的正确性,但是性能会有所降低
非公平所: 线程为了性能好,执行的顺序可能实现定义好的不一样,非公平锁的吞吐量要比公平锁大
Synchronized和Lock都属于非公平所
可重入锁又成为递归锁
代码
public synchronized void method1(){
method2();
}
public synchronized void method2(){
sout();
}
当线程进入方法一时,也会进入方法二,因为他们两个持有同一把锁,这就是可重入锁
可重入锁最大的好处就是避免死锁
死锁产生的条件:
1.循环等待
2.不可剥夺
3.资源独占
4.保持申请
自旋锁SpinLock 阻塞的时候不会一直等候,而是边做自己的事情边等待锁的释放
ReadWriteLock 读写锁 读的时候,不互斥,写的时候,互斥