最近面试被问到并发问题的解决方案,也就涉及到Java中synchronized与lock的区别,之前只是大概了解了下,现在详细整理一下。
1.Java中synchronized与lock的区别
- synchronized是隐式加锁,lock是显示加锁;
- synchronized是在方法上或者方法体上加锁,lock一般是在方法内加锁;
- synchronized采用悲观锁机制,lock采用乐观锁机制;
- lock支持可中断锁,公平锁和非公平锁;synchronized不支持。
2.逐一解释
2.1 隐式加锁与显示加锁
隐式加锁是指由JVM来完成获取锁与释放锁;显示加锁是由自身的Java代码来完成获取锁与释放锁,比如ReentranLock.
2.2 悲观锁与乐观锁
乐观锁是指默认锁是空闲的,没有被别的线程占用,每次都会直接去尝试获取,如果被占用,就直接返回;
悲观锁是指当锁被占用的时候,其他线程只能处于阻塞状态,直到锁被释放,CPU切换线程阻塞会引起线程上下文切换,频繁的上下文切换导致效率比较低下