面试官问:Synchronized与Lock的有什么区别?
表层区别:
他们都可以解决线程同步的问题,synchronized是关键字,Lock是JUC下的接口。
实现方式:
-
synchronized可以锁类、锁对象、锁方法,是JVM级别的,比如锁对象的情况,对象头上会有锁标志,以及等待执行的线程队列。Lock是用户态的,比如ReentrantLock、ReentrantReadWriteLock是通过AQS,基于信号量以及CAS实现的,性能相对较高。
-
在JDK6之前,synchronized被认为是重量级锁,因为进入到synchronized同步块之后,cpu如果无法获取到锁,就会转而执行其他线程,使得用户态与内核态切换频繁。但在1.6之后,JDK做了较多优化,引入了锁升级的机制(一开始是偏向锁,当只有一个线程获取锁时,锁的状态是偏向锁,对象头记录了当前占有锁的线程ID,当前线程可以直接获得锁,当另外一个线程来抢占锁时,锁升级为轻量级锁(自旋锁),引入自旋锁是因为大部分线程持有锁的时间一般都很短,频繁的线程切换会造成更大的性能损失,线程会自旋尝试获得锁,如果成功获得锁就继续执行,如果自旋一定次数后,就转为重量级锁,cpu将该线程挂起,执行其他线程)以及锁消除、锁粗化的优化,所以现在的synchronized的锁也没有那么重了。
-
在复杂且高并发场景下,Lock的性能会更高,因为它是基于CAS实现的,而synchronized在高并发下自旋会经常失败,性能会降低。
-
另外Lock中ReentrantLock可以设置多个condition,能适应复杂场景,而synchronized只能锁一个对象。
-
synchronized是非公平锁,如果要实现公平锁,就要用Lock
-
Lock中如ReentrantLock实现可以响应中断,使得阻塞线程可以响应中断,而synchronized不行
暂时先说到这里