synchronized和ReentrantLock区别:
ReentrantLock | synchronized |
---|---|
ReentrantLock是类,jdk层面实现 | synchronized是关键字,JVM层面实现 |
手动显示加锁解锁,lock(),unlock()方法 | 自动加锁解锁 |
可中断 | 不可中断 |
可实现公平锁或非公平锁 | 只能是非公平锁 |
通过 Condition 可以绑定多个条件 | 不可以绑定多个条件 |
发生异常时,如果没有主动通过 unLock()去释放锁,会死锁,需要在 finally 块中释放锁 | 发生异常时,自动释放线程占有的锁,不会死锁 |
可以知道有没有成功获取锁 | 不可以知道有没有成功获取锁 |
synchronized底层实现原理:
方法级:ACC_SYNCHRONIZED
代码块:monitorenter、monitorexit
对象的对象头中Mark Word 会存储锁信息
https://blog.csdn.net/weixin_38481963/article/details/88384493
ReentrantLock主要利用CAS+AQS队列来实现。
CAS:Compare and Swap,比较并交换。CAS有3个操作数:内存值V、预期值A、要修改的新值B。当且仅当预期值A和内存值V相同时,将内存值V修改为B,否则什么都不做。
AbstractQueuedSynchronizer(队列同步器) 简称AQS