您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Synchronized是否升級到重量級鎖之后就下不來”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Synchronized是否升級到重量級鎖之后就下不來”吧!
我們直接看鎖對象的鎖標志來判斷。
直接上實驗代碼。
代碼非常簡單,先看下無鎖的對象布局,然后多線程爭搶此時應(yīng)該是重量級鎖,然后 sleep 等待所有線程執(zhí)行完畢釋放鎖,然后再看看此時的鎖布局。
最后再加一次鎖看看對象布局。
這里有個注意點
1.8 的偏向鎖是會延遲生效的,得在 JVM 啟動 4 秒后生效,通過 -XX:BiasedLockingStartupDelay=0關(guān)閉偏向鎖延遲
這邊我沒搞這個參數(shù),因為不是重點,所以等下結(jié)果里面不會有偏向鎖。
上結(jié)果!
結(jié)果顯而易見,初始是無鎖的。
然后4個線程同時競爭變成了重量級鎖。
4個線程執(zhí)行完畢之后,鎖對象變成了無鎖。
此時再有一個線程去爭搶鎖,就從無鎖變成了輕量級鎖。
所以當重量級鎖釋放了之后,鎖對象是無鎖的!
有新的線程來競爭的話又會從輕量級鎖開始!
好了,over。
想要自己測試的話,引用一個 jol 的包即可
<dependency> <groupId>org.openjdk.jol</groupId> <artifactId>jol-core</artifactId> <version>0.14</version> </dependency>
代碼也直接拷給你們:
`public class YesLockTest {
static Object yesLock;
public static void main(String[] args) throws InterruptedException {
yesLock = new Object();
System.out.println("無鎖時對象布局:" + ClassLayout.parseInstance(yesLock).toPrintable());
IntStream.rangeClosed(1,4).forEach(i->{getYesLock();});
Thread.sleep(5000L);
System.out.println("無競爭之后,此時的對象布局:" + ClassLayout.parseInstance(yesLock).toPrintable());
getYesLock();//此時再來一次加鎖
}
private static void getYesLock() {
new Thread(() -> {
try {
synchronized (yesLock) {
System.out.println("線程[" + Thread.currentThread().getName() + "]" +
":重量級鎖狀態(tài)對象布局:" + ClassLayout.parseInstance(yesLock).toPrintable());
}
} catch (Exception e) {
e.printStackTrace();
}
}).start();
}
}
到此,相信大家對“Synchronized是否升級到重量級鎖之后就下不來”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。