Synchronized 和 ReentrantLock的区别

孤者浪人 提交于 2020-01-11 16:31:46

Synchronized 和 ReentrantLock的区别:

1、相同点:

(1)都是用来协调多线程对共享对象、变量的访问。即防止多个线程同时访问共享资源。

(2)都是可重入锁,同一线程可以多次获得同一个锁

(3)都保证了可见性和互斥性。互斥性就是一个线程得到锁了,其他线程得不到了。

2、区别:

(1)ReentrantLock 是 API 级别的,synchronized 是 JVM 级别的。

(2)ReentrantLock 显示的获得、释放锁,synchronized 隐式获得释放锁。

(3)ReentrantLock 可以实现公平锁,ReentrantLock 提供了构造器,能够控制锁是否公平,即FIFO谁先来的,谁先获得锁,获取锁的时候排队。

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

(5)Lock 可以让等待锁的线程响应中断,即在获取锁的过程中可以中断当前线程,而 synchronized 却不行,使用 synchronized 时,等待的线程会一直等待下去,不能够响应中断。

(6)通过 Lock 可以知道有没有成功获取锁,而 synchronized 却无法办到。

(7) Lock 可以提高多个线程进行读操作的效率,既就是实现读写锁等。

 

(8)Lock 是一个接口,而 synchronized 是 Java 中的关键字,synchronized 是内置的语言实现。

(9) ReentrantLock 通过 Condition 可以绑定多个条件

(10)底层实现不一样, synchronized 是同步阻塞,使用的是悲观并发策略,lock 是同步非阻塞,采用的是乐观并发策略

 

注:重点是前7个,防止给自己埋坑,不谈底层实现,不谈其他的条件。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!