偏向锁

本文深入探讨Java中偏向锁的工作原理,介绍其如何通过减少锁获取成本提高多线程应用性能。当线程首次获取锁时,偏向锁会在对象头记录线程ID,后续访问同一锁时无需CAS操作,直接测试对象头即可,有效降低锁竞争。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在大多数情况下,锁不存在多线程竞争,而且往往是由一个线程多次获得,为了使线程获得锁的代价更低,引入了偏向锁。

工作原理

偏向锁,顾名思义,它会偏向最先获得它的线程,当一个线程访问同步代码块获得锁时,会在对象头和栈帧记录里存储锁偏向的线程ID,当这个线程再次进入同步代码块时,就不需要CAS操作来加锁了,只要测试一下对象头里是否存储着指向当前线程的偏向锁。如果测试成功,则表明该线程已经获得了锁,如果失败,则减产偏向锁的标示是否设为1,也就是当前是否是偏向锁,如果是,则尝试用CAS操作将对象头的偏向锁指向当前线程,如果不是,则用CAS竞争锁。

撤销

当有其他线程竞争偏向锁的时候,持有偏向锁的线程才会释放锁。当前持有偏向锁的线程如果处于不活动的状态,则直接将对象头设置为无锁状态;如果线程仍然活动,拥有偏向锁的栈会被执行,然后将锁偏向于其他线程,或者恢复到无锁状态。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值