关注
首先在来接syn锁之前,需要了解我们java中对象头的结构,对象头中包含objectheader,class work以及我们的markword,markword主要从初hashcode 分代年龄等信息,首先对于原始的syn锁,我们也叫他重量级锁,在对对象加锁的过程中,会调用native方法跟操作系统申请一个监视器对象,然后将二者关联起来,在关联的过程中,会讲对象头中的markword交给monitor管理,然后markword存储对应monitor的地址,方便我们后续加锁的时候寻址,syn锁是基于monitor实现的,他里面包含owner来存储thread对象,为null则表示当前没有线程获取锁,不为null则表示已经有人获取锁了,会进入到entryset中排队等待,当然如果获取锁的线程由于一些i蛀牙UN没有准备好,进入wait,会释放锁然后进入到waitset中等待,当其他持有锁的线程进行notify后会将waitset中线程放入到entryset中等待,这个set是无序集合,所以不确定哪个线程被调度后持所锁,所以syn是非公平锁,由于加锁每次都需要跟操作系统申请monitor,这个操作sh比较重的,所以jvm底层做了很多优化,比如:重量级锁的自旋,没获取到锁在重试几次,减少线程从运行变更为阻塞状态的上下文切换,还有就是轻量级锁,使用场景是不存咋锁竞争的情况,他会在当前thread staack中创建一个lock record记录,然后将lock record 和 对象头中的markword进行 cas交换,如果当前线程发生了锁重入,发现markword里面存的lockrecrd是当前线程会将所重入的lock 记录 方null,用来记录所重入的次数,释放锁则移除一个lock rerecord,后续如果发生锁竞争,还是会走cas操作尝试交换信息,结果发现已经被交换完了,说明发生了锁竞争就会走锁锁膨胀逻辑,变成重量级锁,然后本身持有轻量级锁的线程会走重量级锁的释放锁的流程.......当然如果不存在锁竞争的情况下,频繁发生自旋,每次都要cas操作,效率也比较低,底层做了优化,干脆直接把线程id刻到markword里面,这也就是偏向锁.......
查看原帖
9 评论
相关推荐
点赞 评论 收藏
分享
02-27 12:37
上海大学 人工智能 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 三月的小目标 #
18870次浏览 366人参与
# 27届求职交流 #
7384次浏览 182人参与
# 神州信息求职进展汇总 #
4104次浏览 73人参与
# 交出你的校招焚诀 #
14314次浏览 233人参与
# 工作后明白的那些道理 #
56198次浏览 875人参与
# 面试___岗的必刷题单 #
15682次浏览 284人参与
# 26届求职交流 #
5051次浏览 104人参与
# AI“智障”时刻 #
28571次浏览 133人参与
# 学历or实习经历,哪个更重要 #
239193次浏览 1242人参与
# 求职遇到的搞笑事件 #
164687次浏览 895人参与
# 机械制造秋招总结 #
106020次浏览 889人参与
# 牛客AI文生图 #
20639次浏览 232人参与
# 实习生至暗时刻 #
21996次浏览 427人参与
# 哪些公司开暑期实习了? #
24432次浏览 206人参与
# 实习想申请秋招offer,能不能argue薪资 #
225734次浏览 1207人参与
# 米哈游求职进展汇总 #
588561次浏览 3028人参与
# 公司情报交流地 #
145250次浏览 1282人参与
# 找AI工作应该卷什么? #
6280次浏览 102人参与
# 你觉得第一学历对求职有影响吗? #
234885次浏览 1282人参与
# 字节开奖 #
131610次浏览 608人参与
# 美团开奖 #
395529次浏览 1793人参与