一、原始构成
synchronized是关键字属于JVM层面
monitorenter(底层是通过monitor对象来完成,其实wait/notify等方法也依赖于monitor对象,只有在同步块或方法中才能调wait/notify等方法)
monitorexit
lock是具体类(java.util.concurrent.locks.Lock)是api层面的锁
synchronized不需要用户去手动释放锁,当synchronized代码执行完后,系统会自动让线程释放对锁的占用。
ReentrantLock则需要用户去手动释放锁,若没有主动释放锁,就有可能导致出现死锁现象。
需要lock()和unlock()方法配合try/finally语句块来完成。
三、等待是否可中断synchronized不可中断,除非抛出异常或者正常运行完成
ReentrantLock可中断
1. 设置超时方法tryLock(long timeout, TimeUnit unit)
2. lockInterruptibly()放代码块中,调用interrupt() 方法可中断
四、加锁是否公平synchronized非公平锁
ReentrantLock两者都可以,默认非公平锁,构造方法可以传入boolean值,true为公平锁,false为非公平锁
synchronized没有
ReentrantLock用来实现分组唤醒需要唤醒的线程们,可以精确唤醒,而不是像synchrnozed要么随机唤醒一个线程要么唤醒全部线程。
class ShareResource {
private int number = 1; //A:1 B:2 C:3
private Lock lock = new ReentrantLock();
private Condition c1 = lock.newCondition();
private Condition c2 = lock.newCondition();
private Condition c3 = lock.newCondition();
public void print5() {
lock.lock();
try {
//1 判断
while (number != 1) {
c1.await();
}
//2 干活
for (int i=1; i {
for (int i=1; i {
for (int i=1; i {
for (int i=1; i
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?