无锁、偏向锁、轻量级锁、重量级锁

无锁、偏向锁、轻量级锁、重量级锁,第1张

无锁、偏向锁、轻量级锁、重量级锁 无锁、偏向锁、轻量级锁、重量级锁 1、偏向锁、轻量级锁、重量级锁适用于不同的并发场景
  • 偏向锁:无实际的锁竞争,且将来只有第一个申请锁的线程会使用锁。偏向锁只有初始化时需要一次CAS
  • 轻量级锁:无实际的锁竞争,多个线程交替使用锁,允许短时间的锁竞争。轻量级锁每次申请、释放锁都至少需要一次CAS
  • 重量级锁:有实际的锁竞争,且锁竞争时间长。
2、锁升级、撤销的流程图

3、内置锁和显示锁

内置锁:也就是Synchronized锁

  • 由Synchronized实现的内置锁才能锁升级,从偏向锁-轻量级锁-重量级锁
  • 执行完同步代码,会自动的释放锁
  • 基于JVM实现,可以对Synchronized锁进行增加锁粒度和减低锁粒度(修饰实例方法、修饰静态方法、修饰代码块
  • 相对显示锁来说,内置锁还是过重,因为内置锁是一个互斥锁,不仅读写互斥并且读读也互斥,最多只有一个线程能够获得该锁,当线程A尝试去获得线程B持有的内置锁时,线程A必须等待或者阻塞,直到线程B释放这个锁。
  • synchronized关键字不能继承,父类方法中加了synchronized,在子类中覆盖了这个方法,在子类中的这个方法默认情况下并不是同步的,需要重新加锁。
  • 内置锁是非公平锁,线程在竞争synchron

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5562650.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-14
下一篇 2022-12-14

发表评论

登录后才能评论

评论列表(0条)

保存