java锁
种类
1 乐观锁,悲观锁
判断依据:线程是否需要锁住同步资源
实现方法:synchronized 悲观锁
乐观锁:AtomicInteger,通常实现要用到CAS算法比较并替换
(***CAS 即比较并替换,实现并发算法时常用到的一种技术。CAS操作包含三个操作数——内存位置、预期原值及新值。执行CAS操作的时候,将内存位置的值与预期原值比较,如果相匹配,那么处理器会自动将该位置值更新为新值,否则,处理器不做任何操作。*)
2 读锁,写锁
判断依据:锁住同步资源失败,线程是否阻塞
接口ReadWriteLock
实现类ReentrantReadWriteLock
内部类 readLock和writeLock
其中有用到AbstractQueuedSynchronizer 即AQS同步队列它是带头结点的双向链式存储结构的队列
3 重入锁,非重入锁
判断依据:一个线程的多个流程能不能获取同一把锁
判断锁的拥有者是不是自己,如果是自己则可以继续加速
while(isLocked && lockedBy != thread){
wait();
}
4 公平锁,非公平速
判断依据:多个线程竞争是否排队
使用方法:ReentrantLock
内部类
FairSync
NonfairSync
5 自旋锁,适应性自旋锁
判断依据:锁住同步资源失败,线程是否阻塞
自旋锁利用的是CAS算法,不停地尝试获取锁,不会阻塞
6 无锁,偏向锁,轻量级锁,重量级锁
偏向锁目前jdk版本都会自动开启
-XX:-UseBiasedLocking=false,关闭偏向锁
轻量级锁,不停CAS
重量级锁 同步锁synchronized