java鎖的差別有哪些
公平鎖定/非公平鎖定
#公平鎖定是指多個執行緒依照申請鎖定的順序來取得鎖。
非公平鎖定是指多個執行緒取得鎖定的順序並不是依照申請鎖的順序,有可能後申請的執行緒比先申請的執行緒優先取得鎖定。有可能,會造成優先反轉或飢餓現象。
對於Java ReentrantLock而言,透過建構函式指定該鎖是否為公平鎖,預設為非公平鎖。非公平鎖的優點在於吞吐量比公平鎖大。
對於Synchronized而言,也是一種非公平鎖。由於其並不像ReentrantLock是透過AQS的來實現執行緒調度,所以並沒有任何辦法使其變成公平鎖。
可重入鎖定
可重入鎖定又稱為遞歸鎖,是指在同一個執行緒在外層方法取得鎖的時候,在進入內層方法會自動取得鎖。說的有點抽象,下面會有一個程式碼的範例。
對於Java ReentrantLock而言, 他的名字就可以看出是一個可重入鎖,其名字是Re entrant Lock重新進入鎖。
對於Synchronized而言,也是一個可重入鎖。可重入鎖的一個好處是可一定程度避免死鎖。
synchronized void setA() throws Exception{ Thread.sleep(1000); setB(); } synchronized void setB() throws Exception{ Thread.sleep(1000); }
上面的程式碼就是一個可重入鎖的一個特點,如果不是可重入鎖的話,setB可能不會被目前執行緒執行,可能造成死鎖。
獨享鎖定/共享鎖定
獨享鎖定是指該鎖定一次只能被一個執行緒所持有。
共享鎖定是指該鎖定可被多個執行緒所持有。
對於Java ReentrantLock而言,其是獨享鎖。但對於Lock的另一個實作類ReadWriteLock,其讀鎖是共享鎖,其寫鎖是獨享鎖。
讀鎖定的共享鎖定可保證並發讀是非常有效率的,讀寫,寫讀 ,寫寫的過程是互斥的。
獨享鎖定與共享鎖定也是透過AQS來實現的,透過實現不同的方法,來實現獨享或共享。
對於Synchronized而言,當然是獨享鎖。
互斥鎖/讀寫鎖定
上面講的獨享鎖定/共享鎖定就是一種廣義的說法,互斥鎖/讀寫鎖定就是具體的實現。
互斥鎖在Java中的具體實作就是ReentrantLock。
讀寫鎖在Java中的具體實作就是ReadWriteLock。
樂觀鎖/悲觀鎖
樂觀鎖與悲觀鎖不是指具體的什麼類型的鎖,而是指看待並發同步的角度。
悲觀鎖定認為對於同一個資料的並發操作,一定是會發生修改的,即使沒有修改,也會認為修改。因此對於同一個資料的並發操作,悲觀鎖採取加鎖的形式。悲觀的認為,不加鎖的並發操作一定會出問題。
樂觀鎖定則認為對於同一個資料的並發操作,是不會發生修改的。在更新資料的時候,會採用嘗試更新,不斷重新的方式更新資料。樂觀的認為,不加鎖的並發操作是沒有事情的。
從上面的描述我們可以看出,悲觀鎖適合寫入操作非常多的場景,樂觀鎖適合讀取操作非常多的場景,不加鎖會帶來大量的效能提升。
悲觀鎖定在Java中的使用,就是利用各種鎖。
樂觀鎖在Java中的使用,是無鎖定編程,常採用的是CAS演算法,典型的例子就是原子類,透過CAS自旋實現原子操作的更新。
分段鎖定
分段鎖定其實是一種鎖定的設計,並不是具體的一種鎖,對於ConcurrentHashMap而言,其並發的實作就是透過分段鎖的形式來實現高效率的並發操作。
我們以ConcurrentHashMap來說一下分段鎖定的意義以及設計思想,ConcurrentHashMap中的分段鎖定稱為Segment,它即類似於HashMap(JDK7與JDK8中HashMap的實作)的結構,即內部擁有一個Entry數組,數組中的每個元素又是一個鍊錶;同時又是一個ReentrantLock(Segment繼承了ReentrantLock)。
當需要put元素的時候,並不是對整個hashmap進行加鎖,而是先透過hashcode來知道他要放在那一個分段中,然後對這個分段進行加鎖,所以當多執行緒put的時候,只要不是放在一個分段中,就實現了真正的平行的插入。
但是,在統計size的時候,可就是取得hashmap全域資訊的時候,就需要取得所有的分段鎖才能統計。
分段鎖的設計目的是細化鎖的粒度,當操作不需要更新整個數組的時候,就僅針對數組中的一項進行加鎖操作。
偏向鎖定/輕量級鎖定/重量級鎖定
這三種鎖定是指鎖的狀態,並且是針對Synchronized。在Java 5透過引入鎖定升級的機制來實現高效Synchronized。這三種鎖的狀態是透過物件監視器在物件頭中的欄位來表示的。
偏向鎖定是指一段同步程式碼一直被一個執行緒所訪問,那麼該執行緒會自動取得鎖。降低獲取鎖的代價。
輕量級鎖是指當鎖是偏向鎖的時候,被另一個線程所訪問,偏向鎖就會升級為輕量級鎖,其他線程會透過自旋的形式嘗試獲取鎖,不會阻塞,提高性能。
重量級鎖是指當鎖為輕量級鎖的時候,另一個執行緒雖然是自旋,但自旋不會一直持續下去,當自旋一定次數的時候,還沒有取得到鎖,就會進入阻塞,鎖膨脹為重量級鎖。重量級鎖會讓其他申請的線進入阻塞,效能降低。
自旋鎖定
在Java中,自旋鎖定是指嘗試取得鎖定的執行緒不會立即阻塞,而是採用循環的方式去嘗試取得鎖,這樣的好處是減少線程上下文切換的消耗,缺點是循環會消耗CPU。
php中文網,大量的免費Java入門教學,歡迎線上學習!
以上是java鎖的差別有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

多線程和異步的區別在於,多線程同時執行多個線程,而異步在不阻塞當前線程的情況下執行操作。多線程用於計算密集型任務,而異步用於用戶交互操作。多線程的優勢是提高計算性能,異步的優勢是不阻塞 UI 線程。選擇多線程還是異步取決於任務性質:計算密集型任務使用多線程,與外部資源交互且需要保持 UI 響應的任務使用異步。

在 C 語言中,char 和 wchar_t 的主要區別在於字符編碼:char 使用 ASCII 或擴展 ASCII,wchar_t 使用 Unicode;char 佔用 1-2 個字節,wchar_t 佔用 2-4 個字節;char 適用於英語文本,wchar_t 適用於多語言文本;char 廣泛支持,wchar_t 依賴於編譯器和操作系統是否支持 Unicode;char 的字符範圍受限,wchar_t 的字符範圍更大,並使用專門的函數進行算術運算。

C語言中沒有內置求和函數,需自行編寫。可通過遍歷數組並累加元素實現求和:循環版本:使用for循環和數組長度計算求和。指針版本:使用指針指向數組元素,通過自增指針遍歷高效求和。動態分配數組版本:動態分配數組並自行管理內存,確保釋放已分配內存以防止內存洩漏。

C語言函數是代碼模塊化和程序搭建的基礎。它們由聲明(函數頭)和定義(函數體)組成。 C語言默認使用值傳遞參數,但也可使用地址傳遞修改外部變量。函數可以有返回值或無返回值,返回值類型必須與聲明一致。函數命名應清晰易懂,使用駝峰或下劃線命名法。遵循單一職責原則,保持函數簡潔性,以提高可維護性和可讀性。

C和C#雖有類似之處,但截然不同:C是面向過程、手動內存管理、平台依賴的語言,用於系統編程;C#是面向對象、垃圾回收、平台獨立的語言,用於桌面、Web應用和遊戲開發。

DOM節點下XPath查找方法詳解在JavaScript中,我們經常需要根據XPath表達式從DOM樹中查找特定的節點。如果需要從某�...

char 和 unsigned char 是存儲字符數據的兩種數據類型,主要區別在於處理負數和正數的方式:值範圍:char 有符號 (-128 到 127),unsigned char 無符號 (0 到 255)。負數處理:char 可以存儲負數,unsigned char 不能。位模式:char 最高位表示符號,unsigned char 無符號位。算術運算:char 和 unsigned char 作為有符號和無符號類型,其算術運算方式不同。兼容性:char 和 unsigned char

H5、小程序和APP的主要區別在於:技術架構:H5基於網頁技術,小程序和APP為獨立應用程序。體驗和功能:H5輕便易用,功能受限;小程序輕量級,交互性好;APP功能強大,體驗流暢。兼容性:H5跨平台兼容,小程序和APP受平台限制。開發成本:H5開發成本低,小程序中等,APP最高。適用場景:H5適合信息展示,小程序適合輕量化應用,APP適合複雜功能應用。
