Java并发编程之Monitor工作原理(有图解)

Monitor

Monitor被翻译为监视器管程

每个Java对象都可以关联一个Monitor对象,如果使用synchronized给对象上锁(重量级)之后,该对象头的Mark Word中就被设置指向Monitor对象的指针。

Monitor结构如下:

请添加图片描述
当使用synchronized给对象上锁的时候,这个对象就会跟Monitor进行关联。步骤如下:

当有一个线程执行synchroniezd(obj)这段代码时,obj对象就会跟操作系统提供的Monitor对象相关联。

请添加图片描述

具体是用一个指针指向Monitor对象,地址存储在MarkWord里。

请添加图片描述

此时线程Thread-2成功获取了Monitor锁,Owner表示的是哪一个线程获取了这把锁。

请添加图片描述

如有别的线程打算执行synchroniezd(obj)这段代码时,它会先判断obj是否有关联Monitor锁,如已经关联Monitor锁,再去判断这把锁是否有主人(Owner),Monitor中Owner只能有一个,如这把锁已经有主人(Owner),此时线程就会关联EntryList(EntryList是一个阻塞队列,关联了EntryList的线程都变成阻塞状态,底层是链表结构)。

请添加图片描述

当Thread-2把临界区代码执行完后,这个锁就会被释放,Owner就会空出来,这时会唤醒EntryList中的线程,在EntryList中的线程开始竞争,由竞争成功的线程获得这个锁。

请添加图片描述

总结:

  • 刚开始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中等待的线程来竞争锁,竞争时是非公平的,具体结果由jvm决定
  • 图中WaitSet中的Thread-0,Thread-1是之前获得过锁,但条件不满足进入WAITING状态的线程。

注意:

  • synchronized必须是进入同一个对象的monitor才有上述的效果
  • 不加synchronized的对象不会关联监视器,不遵从以上规则
  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值