关注
首先在来接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里面,这也就是偏向锁.......
查看原帖
8 评论
相关推荐
点赞 评论 收藏
分享
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 腾讯音乐求职进展汇总 #
58282次浏览 344人参与
# 0offer互助地 #
292366次浏览 2343人参与
# 牛友故事会 #
330128次浏览 8763人参与
# 投递几十家公司,到现在0offer,大家都一样吗 #
171229次浏览 1172人参与
# 双非本科的出路是什么? #
108315次浏览 1043人参与
# 工作中,努力重要还是选择重要? #
84856次浏览 1128人参与
# lastday知无不言 #
41619次浏览 390人参与
# 生化医药面经大本营 #
89611次浏览 448人参与
# 今年秋招哪家公司给的薪资最良心? #
187951次浏览 1096人参与
# 22届毕业,是读研还是拿外包offer先苟着 #
6362次浏览 31人参与
# 学历or实习经历,哪个更重要 #
77792次浏览 615人参与
# 你的秋招第一面感觉怎么样 #
62024次浏览 508人参与
# 选择和努力,哪个更重要? #
59137次浏览 598人参与
# 互联网回暖,腾讯要招5000+人! #
259563次浏览 4879人参与
# 我和xx公司的爱恨情仇 #
36586次浏览 304人参与
# 我在牛爱网找对象 #
162488次浏览 1228人参与
# 如何KTV领导 #
44697次浏览 360人参与
# 远程面试的尴尬瞬间 #
71656次浏览 626人参与
# 互联网公司评价 #
350432次浏览 3659人参与
# 秋招被确诊为…… #
150050次浏览 691人参与