synchronized和ReentrantLock区别

  • 相同点

都是用来协调多线程对共享对象、变量的访问都是可重入锁,同一线程可以多次获得同一个锁,都保证了可见性和互斥性。

  • 不同点

1、底层实现不一样,synchronized它是java语言的关键字,是原生语法层面的互斥,需要jvm实现。而ReentrantLock它是JDK 1.5之后提供的API层面的互斥锁,需要lock()和unlock()方法配合try/finally语句块来完成。也就是说synchronized隐式获得释放锁,ReentrantLock 显示的获得、释放锁。

附源码 :

synchronized和ReentrantLock区别_第1张图片

synchronized字节码

synchronized和ReentrantLock区别_第2张图片

ReentrantLock API 

2、synchronized在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;而Lock 在发生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用Lock 时需要在 finally块中释放锁。

3、synchronized是同步阻塞,使用的是悲观并发策略,lock是同步非阻塞,采用的是乐观并发策略。

4、ReentrantLock可以让等待锁的线程响应中断,而synchronized却不行,使用synchronized时,等待的线程会一直等待下去,不能够响应中断。通过ReentrantLock可以知道有没有成功获取锁,而synchronized却无法办到。最重要的是ReentrantLock可以提供公平锁,而synchronized只能是非公平锁。公平锁、非公平锁,这里写一个示例代码:

 首先重写ReentrantLock中的getQueuedThreads方法(便于观察日志输出)

synchronized和ReentrantLock区别_第3张图片

getQueuedThreads

synchronized和ReentrantLock区别_第4张图片

定义线程

synchronized和ReentrantLock区别_第5张图片

 公平锁执行结果

synchronized和ReentrantLock区别_第6张图片

可以看出公平锁锁是按顺序执行的,而非公平锁没有按顺序执行。ReentrantLock默认是非公平锁,需要创建的时候设置为true标识公平锁。

5、ReentrantLock可以提高多个线程进行读操作的效率,实现读写锁。

synchronized和ReentrantLock区别_第7张图片

读写锁

synchronized和ReentrantLock区别_第8张图片

读写锁执行

synchronized和ReentrantLock区别_第9张图片

读写锁执行结果

可以有多个线程同时读,但是当出现写操作时,就只能有一个线程操作。

6、ReentrantLock通过Condition可以绑定多个条件。

 

转载来源:https://baijiahao.baidu.com/s?id=1652543241208099679&wfr=spider&for=pc

你可能感兴趣的:(synchronized和ReentrantLock区别)