您好,登錄后才能下訂單哦!
本篇內容主要講解“Synchronized是否升級到重量級鎖之后就下不來”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Synchronized是否升級到重量級鎖之后就下不來”吧!
我們直接看鎖對象的鎖標志來判斷。
直接上實驗代碼。
代碼非常簡單,先看下無鎖的對象布局,然后多線程爭搶此時應該是重量級鎖,然后 sleep 等待所有線程執行完畢釋放鎖,然后再看看此時的鎖布局。
最后再加一次鎖看看對象布局。
這里有個注意點
1.8 的偏向鎖是會延遲生效的,得在 JVM 啟動 4 秒后生效,通過 -XX:BiasedLockingStartupDelay=0關閉偏向鎖延遲
這邊我沒搞這個參數,因為不是重點,所以等下結果里面不會有偏向鎖。
上結果!
結果顯而易見,初始是無鎖的。
然后4個線程同時競爭變成了重量級鎖。
4個線程執行完畢之后,鎖對象變成了無鎖。
此時再有一個線程去爭搶鎖,就從無鎖變成了輕量級鎖。
所以當重量級鎖釋放了之后,鎖對象是無鎖的!
有新的線程來競爭的話又會從輕量級鎖開始!
好了,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() + "]" +
":重量級鎖狀態對象布局:" + ClassLayout.parseInstance(yesLock).toPrintable());
}
} catch (Exception e) {
e.printStackTrace();
}
}).start();
}
}
到此,相信大家對“Synchronized是否升級到重量級鎖之后就下不來”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。