- 偏向锁:无实际的锁竞争,且将来只有第一个申请锁的线程会使用锁。偏向锁只有初始化时需要一次CAS
- 轻量级锁:无实际的锁竞争,多个线程交替使用锁,允许短时间的锁竞争。轻量级锁每次申请、释放锁都至少需要一次CAS
- 重量级锁:有实际的锁竞争,且锁竞争时间长。
内置锁:也就是Synchronized锁
- 由Synchronized实现的内置锁才能锁升级,从偏向锁-轻量级锁-重量级锁
- 执行完同步代码,会自动的释放锁
- 基于JVM实现,可以对Synchronized锁进行增加锁粒度和减低锁粒度(修饰实例方法、修饰静态方法、修饰代码块
- 相对显示锁来说,内置锁还是过重,因为内置锁是一个互斥锁,不仅读写互斥并且读读也互斥,最多只有一个线程能够获得该锁,当线程A尝试去获得线程B持有的内置锁时,线程A必须等待或者阻塞,直到线程B释放这个锁。
- synchronized关键字不能继承,父类方法中加了synchronized,在子类中覆盖了这个方法,在子类中的这个方法默认情况下并不是同步的,需要重新加锁。
- 内置锁是非公平锁,线程在竞争synchron
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)