Java Mark Word和锁

Mark Word简介

Mark Word在64位的虚拟机中也占64位,是每一个对象都有的一个值。这个区域记录了很多信息,并根据对象的锁状态能表达很多不同的意思。如下:
在这里插入图片描述头2位为标志位:如上图所示,虚拟机根据这2位的判断该对象作为锁的状态,然后再去读之后若干位的数据并判断状态。

三种机制的切换是根据竞争激烈程度进行的, 在几乎无竞争的条件下, 会使用偏向锁, 在轻度竞争的条件下, 会由偏向锁升级为轻量级锁, 在重度竞争的情况下, 会升级到重量级锁。

  • 偏向锁:只有一个线程进入临界区;
  • 轻量级锁:多个线程交替进入临界区;
  • 重量级锁:多个线程同时进入临界区。

在这里插入图片描述

偏向锁:

锁会偏向于第一个获取它的线程,如果这个锁在之后的执行过程中一直没有被其他线程获取,那么持有这个偏向锁的线程之后的操作则不需要同步。-XX:+UseBiasedLocking
在这里插入图片描述由于Mark Word的规则,偏向锁状态和正常状态的前2位是一致的,第3位是判断是否为偏向锁锁定,若是则后续保存了Thread ID;若不是则保存一致性hashcode。一旦要获取hashcode,偏向锁是无法用的。

在这里插入图片描述

轻量级锁:

在这里插入图片描述轻量级锁采用自旋+CAS方式不断获取锁-XX:+UseSpinning,默认是10次,使用-XX:PreBlockSpin来修改
在这里插入图片描述

重量级锁

moniterenter和moniterexit这2个指令,操作系统层面的挂起。

参考

1. Java中的偏向锁,轻量级锁, 重量级锁解析
2. 通俗易懂 悲观锁、乐观锁、可重入锁、自旋锁、偏向锁、轻量/重量级锁、读写锁、各种锁及其Java实现!
3.synchronized锁定的到底是什么?
4.一个synchronized跟面试官扯了半个小时

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值