synchronized底层如何实现的?大家一般怎么回答

我这样回答面试官说不对`````````````````````````

代码块同步是使用monitorenter和monitorexit指令实现, monitorenter指令是在编译后插入到同步代码块的开始位置,而monitorexit是插入到方法结束处和异常处, JVM要保证每个monitorenter必须有对应的monitorexit与之配对。任何对象都有一个 monitor 与之关联,当且一个monitor 被持有后,它将处于锁定状态。线程执行到 monitorenter 指令时,将会尝试获取对象所对应的 monitor 的所有权,即尝试获得对象的锁。
全部评论
我自己记得笔记,网易面试也考了这道题 Synchronized的底层实现依赖于JVM, 在 HotSpot JVM实现中,锁有个专门的名字:对象监视器。 当多个线程同时请求某个对象监视器时,对象监视器会设置几种状态用来区分请求的线程: Contention List:一个虚拟的队列,所有请求锁的线程将被首先放置到该竞争队列 Entry List:Contention List中那些有资格成为***的线程被移到Entry List,ContentionList 会被线程并发访问,为了降低对ContentionList队尾的争用 Wait Set:那些调用wait方法被阻塞的线程被放置到Wait Set OnDeck:任何时刻最多只能有一个线程正在竞争锁,该线程称为OnDeck Owner:获得锁的线程称为Owner !Owner:释放锁的线程   具体实现方式是:新请求锁的线程将首先被加入到ConetentionList中,当某个拥有锁的线程(Owner状态)调用unlock之后,如果发现EntryList为空则从ContentionList中移动线程到EntryList,OnDeck线程获得锁后即变为owner线程,无法获得锁则会依然留在EntryList中
点赞 回复 分享
发布于 2016-09-13 18:48
是不是让你说synchronized  1.5以后的优化啊?
点赞 回复 分享
发布于 2016-09-13 18:30
http://blog.csdn.net/niuwei22007/article/details/51433669
点赞 回复 分享
发布于 2016-09-13 18:39
这不是底层吧?
点赞 回复 分享
发布于 2016-09-13 18:42
看源码一下就懂了。
点赞 回复 分享
发布于 2016-09-13 21:21
我当时瞎回答了一通 感觉要跪
点赞 回复 分享
发布于 2016-09-13 21:21
如果光就底层实现来说,楼主你说的没错。抽象模型就是这样的,本质上是通过内存屏障来实现的,其实就是加lock指令。我猜可能面试官想问的是synchronized在java中的运行机制,也就是所谓的锁膨胀的那块东西,属于没有问清楚。
点赞 回复 分享
发布于 2016-09-13 23:16

相关推荐

头像
11-21 11:39
四川大学 Java
是红鸢啊:忘了还没结束,还有字节的5k 违约金
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务