最后
光给面试题不给答案不是我的风格。这里面的面试题也只是凤毛麟角,还有答案的话会极大的增加文章的篇幅,减少文章的可读性
Java面试宝典2021版
最常见Java面试题解析(2021最新版)
2021企业Java面试题精选
从上述分析可以看出,从wait中醒来的A总是比BLOCKING的C先抢占到锁,是因为QMode等于0时JVM先从_EntryList中取线程去竞争锁导致的,我们先来回顾一下QMode的值决定的逻辑:
QMode = 2的操作最特殊:取_cxq队列首元素唤醒;
QMode等于其他值的操作如下:
一、QMode = 3,把cxq队列的首元素放入EntryList尾部,再执行步骤四;
二、QMode = 4,把cxq队列的首元素放入EntryList头部,再执行步骤四;
三、QMode = 0,不做什么,执行步骤4;四、如果EntryList非空,就取首元素唤醒,否则取cxq的首元素唤醒;
现状是这样的:A在EntryList列,C在cxq队列;
综上所述,如果QMode=2,就会直接从_cxq中取出C线程唤醒,这样C就比A先拿到锁了!
开始行动吧,启动docker,打开objectMonitor.cpp文件,找到void ATTR ObjectMonitor::exit(bool notsuspended, TRAPS)方法,找到“int QMode = KnobQMode ;”这段代码,在下面加一行"QMode = 2;",如下图所示:
改完,编译构建JDK吧,对编译有疑问的同学请看《/usr/local/openjdk/build/linux-x86_64-normal-server-slowdebug/jdk/bin,执行命令./java NotifyDemo再次执行demo程序,得到结果如下图所示,线程C比线程A先抢到锁了:
这就结束了?当然没有,还记得之前对QMode的分析么,QMode等于4的时候,会把线程C从cxq队列取出来放在EntryList队列的头部,这样在EntryList中C就排在A前面了,接下来就会从EntryList头部取出线程唤醒,所以,QMode等于4的时候,C也会比A先抢到锁。
修改objectMonitor.cpp源码,把QMode赋值为4,再次编译后,执行./java NotifyDemo,可以看到如下结果:
惊喜
最后还准备了一套上面资料对应的面试题(有答案哦)和面试时的高频面试算法题(如果面试准备时间不够,那么集中把这些算法题做完即可,命中率高达85%+)
et/topics/618154847)收录**