前言
早期的时候我们对线程的主要操作为:
-
synchronized wait notify
然后后面出现了替代方案
-
lock await singal
问题
synchronized 和 lock 有什么区别?用新的lock有什么好处?举例说明
1)原始构成
- synchronized属于JVM层面,属于java的关键字
monitorenter(底层是通过monitor对象来完成,其实wait/notify等方法也依赖于monitor对象 只能在同步块或者方法中才能调用 wait/ notify等方法)
-
Lock是具体类(java.util.concurrent.locks.Lock)是api层面的锁
2)使用方法:
-
synchronized:不需要用户去手动释放锁,当synchronized代码执行后,系统会自动让线程释放对锁的占用
-
ReentrantLock:则需要用户去手动释放锁,若没有主动释放锁,就有可能出现死锁的现象,需要lock() 和 unlock() 配置try catch语句来完成
3)等待是否中断
-
synchronized:不可中断,除非抛出异常或者正常运行完成
-
ReentrantLock:可中断,可以设置超时方法
-
设置超时方法,trylock(long timeout, TimeUnit unit)
-
lockInterrupible() 放代码块中,调用interrupt() 方法可以中断
-
4)加锁是否公平
-
synchronized:非公平锁
-
ReentrantLock:默认非公平锁,构造函数可以传递boolean值,true为公平锁,false为非公平锁
5)锁绑定多个条件Condition
-
synchronized:没有,要么随机,要么全部唤醒
-
ReentrantLock:用来实现分组唤醒需要唤醒的线程,可以精确唤醒,而不是像synchronized那样,要么随机,要么全部唤醒