Monitor概念

@Monitor概念

Monitor概念

Java对象

以32位虚拟机为例
普通对象

|--------------------------------------------------------|
|                 object Header64 bits)                 |
|--------------------------------------------------------|
|          Mark Word32bits)|   Klass Word32bit      |
|-----------------------------|--------------------------|

数组对象

|---------------------------------------------------------------|
|                   object Header(64bits)                     |
|----------------------------|----------------------------------|
|       Mark Word(32 bits) |     Klass Word(32bits)          |
|----------------------------|--------------------------------- |

其中Mark Word结构为

|-------------------------------------------------------|--------------------|
|           Mark Word (32 bits)                         |     State          |
|-------------------------------------------------------|--------------------|
| hashcode:25      |    age:4   |  biased_lock:0  | 01  |    Normal          |
|-------------------------------------------------------|--------------------|
| thread:23   | epoch:2    | age:4 | biased_lock:1 | 01 |       Biased       |
|-------------------------------------------------------|--------------------|
| ptr_to_lock_record:30    | 00                         | Lightweight Locked |
|-------------------------------------------------------|--------------------|
| ptr_to_heavyweight_monitor:30 | 10                    | Heavyweight Locked |
|-------------------------------------------------------|--------------------|
|                                                  | 11 | Marked for GC      |
|-------------------------------------------------------|--------------------|

原理之Monitor(锁)

Monitor 被翻译为监视器管程
每个Java对象都可以关联一个Mointor对象,如果使用synchronized给对象上锁(重量级)之后,该对象头的Mark Word中就被设置指向Monitor对象的指针
Monitor结构如下
在这里插入图片描述

  • 刚开始Monitor中Owner为null
  • 当Thread-2执行synchronized(obj)就会将Monitor的所有者Owner的所有者设置为Thread-2,Monitor中就只能有一个Owner
  • 当Thread-2上锁的过程中,如果Thread-3,Thread-4,Thread-5也来执行synchronized(obj),就会进入EntryList BLOCKED
  • 当Thread-2执行完同步代码块的内容,然后唤醒EntryList中等待的线程来竞争锁,竞争时非公平的
  • 图中WaitSet中的Thread-0,Thread-1是之前获得过的锁,但条件不满足进入WAITING状态的线程
注意
 - synchronized必须是进入同一个对象的Monitor才有上诉的效果
 - 不加synchroized的对象是不会关联监视器,不遵从以上规则

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值