A.原始构成
<1>synchronized关键字属于jvm, 底层是通过monitor对象来完成,其实wait/notify等方法也依赖于monitor对象只有在同步或方法中才能掉wait/notify等方法
<2>Lock是具体类,是api层面的锁(java.util.)
B.使用方法
<1>sychronized不需要用户取手动释放锁,当synchronized代码执行完后系统会自动让线程释放对锁的占用
<2>ReentrantLock则需要用户去手动释放锁若没有主动释放锁,就有可能导致出现死锁现象,需要lock()和unlock()方法配合try/finally语句块来完成
C.等待是否可中断
<1>synchronized不可中断,除非抛出异常或者正常运行完成,有人会举DCL出现指令重排的问题,出现指令重排的原因并不是因为synchronized不可中断,而是操作系统层面出现的重排,一定要区分清楚
<2>ReentrantLock可中断,设置超时方法tryLock(long timeout, TimeUnit unit),或者lockInterruptibly()放代码块中,调用interrupt()方法可中断。
D.加锁是否公平
<1>synchronized非公平锁
<2>ReentrantLock两者都可以,默认公平锁,构造方法可以传入boolean值,true为公平锁,false为非公平锁
E.锁绑定多个条件Condition
<1>synchronized没有
<2>ReentrantLock用来实现分组唤醒需要要唤醒的线程们,可以精确唤醒,而不是像synchronized要么随机唤醒一个线程要么唤醒全部线程。可以实现A->B->C这样的链式唤醒