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个,防止给自己埋坑,不谈底层实现,不谈其他的条件。
来源:https://www.cnblogs.com/guoyu1/p/12180078.html