Synchronized底层——Monitor

本文详细解读了Java中Synchronized锁的实现原理,介绍了Monitor对象在对象头MarkWord中的关联,以及Owner、WaitSet和EntryList的作用。重点讲解了线程同步、公平与非公平竞争以及对象状态还原的过程。
摘要由CSDN通过智能技术生成

Monitor
其中Synchronized锁的本质,就是在对象头的Mark Word中关联一个Monitor对象,这个Monitor对象是操作系统层级实现的对象。

每个Java对象都可以关联一个Monitor对象,如果给这个Java对象使用了Synchronized加上了重量级锁,那么这个对象就会关联一个Monitor对象,在Mark Down中会有一个指针指向这个Monitor对象。

PS:每个Java对象关联的Monitor对象都不一样,所以对不同对象加锁,不能够实现同步的效果。

Monitor的结构如下图所示:

Owner:当前锁的持有者,Owner只能指向一个线程。
WaitSet:等待队列,是之前获得过锁,但是条件不满足后,又退出锁的拥有,等待条件。
EntryList:被阻塞的队列,在Owner指向的对象不为空的时候,有其他线程想要获得锁,那么会进入EntryList队列。

WaitSet和EntryList的区别: EntryList执行条件都满足了,只需要获得锁。WaitSet是条件不满足,如果条件满足的话,重新进入到EntryList进行锁的竞争。

针对上图,当Thread-2执行完同步代码块后,会释放锁的资源,之后唤醒EntryList中的线程,来进行锁的竞争,该竞争是非公平的(不是先到先得)。

在对对象加锁的时候,Mark Word中的分代年龄,HashCode等的数据都存入了Monitor中,在Mark Word中会有一个ptr_to_heavyweight_monitor指针来指向Monitor对象。在对象锁结束的时候,会还原Mark Word中的分代年龄,HashCode等的数据。

原文链接:https://blog.csdn.net/weixin_43606226/article/details/123530728

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值