Java synchronized锁升级过程简述(面试可用)

java 锁升级流程

Synchronized 的锁升级流程是这样:无锁 ----> 偏向锁 ----> 轻量级锁----> 锁自旋 ----> 重量级锁

在这里插入图片描述

偏向锁

偏向锁,简单的讲,就是在锁对象的对象头中有个ThreaddId字段, 这个字段如果是空的,第一次获取锁的时候,就将自身的ThreadId写入到锁的ThreadId字内,将锁头内的是否偏向锁的状态位置1.这样下次获取锁的时候,直接检查ThreadId是否和自身线程Id一致,如果一致,则认为当前线程已经获取了锁,因此不需再次获取锁,略过了轻量级锁和重量级锁的加锁阶段。提高了效率。(摘抄的哈哈)

轻量级锁

轻量级锁,偏向锁是单线程下的锁优化,这个就说多线程下的锁优化了,当有多个 线程竞争同一个临界资源,这个时候偏向锁就会被撤(这个步骤也是十分消耗资源的),然后升级为轻量级锁,这个也是一个基于CAS的乐观锁。

锁自旋

锁自旋,什么是锁自旋呢,很简单就是线程自己做一些无用功,避免线程被挂起阻塞 ,它自己在哪里做一些空任务,然后去竞争锁,避免被挂起阻塞(阻塞和唤醒是又是十分消耗性能的行为,这边涉及到用户态和核心态的操作系统问题,一般我们操作的都是用户态,但是线程的挂起阻塞是需要从用户态切换到核心态,同样,线程唤醒也一样,这个步骤会造成巨大的性能消耗,能避免尽量避免)。当然,锁自旋也是会消耗一定的CPU的

重量级锁

重量级锁,也就是再一次的锁升级。这个时候线程就是进行锁自旋也不到锁,因为锁自旋也是需要消耗一定资源的,所以它不可能一直自旋自旋失败了,那么就进行锁膨胀,升级为重量级锁。

码字不易,给个赞咯
下面是我得公众号二维码,扫一扫可能有惊喜哦哈哈
在这里插入图片描述

  • 9
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 15
    评论
Java中的synchronized锁升级是为了提高多线程并发执行的性能和效率。它通过在锁的使用过程中进行优化和升级来实现。 在Java中,synchronized锁的升级主要涉及三个层面:Java层面、字节码层面和JVM层面(对象头)。 在Java层面上,synchronized锁的升级包括以下几种状态: 1. 无锁状态:多个线程可以同时进入临界区,没有互斥的限制; 2. 偏向锁状态:当只有一个线程访问临界区时,偏向锁可以减少锁的竞争; 3. 轻量级锁状态:多个线程竞争同一个锁时,锁会升级为轻量级锁,通过CAS操作来实现快速的加锁和解锁; 4. 重量级锁状态:多个线程竞争同一个锁时,锁会升级为重量级锁,使用操作系统的互斥量来实现线程的阻塞和唤醒[1]。 在字节码层面上,synchronized同步代码块的锁升级实际上是通过字节码指令来实现的。当进入同步代码块时,会通过monitorenter指令获取锁,在退出同步代码块时,会通过monitorexit指令释放锁。这些指令可以保证临界区的原子性和互斥性,从而实现线程的同步。 在JVM层面上,synchronized锁的升级是通过对象头中的标记位来实现的。对象头中的标记位包括了锁标志位、线程ID和指向锁记录的指针。通过这些标记位,JVM可以判断锁的状态和竞争情况,从而进行锁的升级和降级。 总结来说,Java中的synchronized锁升级是为了提高多线程并发执行的性能和效率。它通过在不同层面上对锁进行优化和升级来实现线程的同步和互斥,从而保证临界区的原子性和正确性。这些优化和升级包括了无锁状态、偏向锁状态、轻量级锁状态和重量级锁状态。
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

memory_cood

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值