您好,登錄后才能下訂單哦!
這篇文章主要介紹了java中怎么實現可重入的自旋鎖的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇java中怎么實現可重入的自旋鎖文章都會有所收獲,下面我們一起來看看吧。
說明
1、是指試圖獲得鎖的線程不會堵塞,而是通過循環獲得鎖。
2、優點:減少上下文切換的消耗。
缺點:循環消耗CPU。
實例
public class ReentrantSpinLock { private AtomicReference<Thread> owner = new AtomicReference<>(); // 可重入次數 private int count = 0; // 加鎖 public void lock() { Thread current = Thread.currentThread(); if (owner.get() == current) { count++; return; } while (!owner.compareAndSet(null, current)) { System.out.println("--我在自旋--"); } } //解鎖 public void unLock() { Thread current = Thread.currentThread(); //只有持有鎖的線程才能解鎖 if (owner.get() == current) { if (count > 0) { count--; } else { //此處無需CAS操作,因為沒有競爭,因為只有線程持有者才能解鎖 owner.set(null); } } } public static void main(String[] args) { ReentrantSpinLock spinLock = new ReentrantSpinLock(); Runnable runnable = () -> { System.out.println(Thread.currentThread().getName() + "開始嘗試獲取自旋鎖"); spinLock.lock(); try { System.out.println(Thread.currentThread().getName() + "獲取到了自旋鎖"); Thread.sleep(4000); } catch (InterruptedException e) { e.printStackTrace(); } finally { spinLock.unLock(); System.out.println(Thread.currentThread().getName() + "釋放了了自旋鎖"); } }; Thread thread1 = new Thread(runnable); Thread thread2 = new Thread(runnable); thread1.start(); thread2.start(); } }
關于“java中怎么實現可重入的自旋鎖”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“java中怎么實現可重入的自旋鎖”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。