您好,登錄后才能下訂單哦!
這篇文章給大家介紹如何進行ConcurrentHashMap集合源碼解析,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
在我們介紹的這么多集合類中只有Hashtable、Stack、Vector這3個集合類是線程安全的,也就是我們不需要添加額外的代碼就可以在多線程環境中使用。當然我們也可以通過添加額外的代碼使一個非線程安全的集合類,變成線程安全的。主要的方式有兩種。
直接使用synchronized同步關鍵字。
別一種是調用Collections類的synchronizedMap方法
下面代碼將創建一個線程安全的HashMap集合
實際上在我們進行多線程開發時,如果需要使用集合時一般不會采用上述的實現方式。而是直接使用一種新的集合實現我們的邏輯,也就是我們今天要分享的ConcurrentHashMap集合。顧名思義這個集合的特性就是保證線程安全的,除此之外,ConcurrentHashMap集合的底層實現還考慮了對性能的優化。
那我們廢話不多說,我們直接分析ConcurrentHashMap集合的底層源碼。首先還是看一下ConcurrentHashMap集合的初始化代碼。
ConcurrentHashMap集合的無參構造方法只是定義了一個空方法并沒有任何實現。在一點和其它集合類的初始化有很大的不同。由于ConcurrentHashMap集合的特性是保證線程安全的。并且我們知道如果在使用集合時發生線程安全問題,那么十有八九的原因是發生在添加元素和刪除元素時的。也就是集合中的對應的put方法和remove方法。所以接下來我們的重點就是詳細分析ConcurrentHashMap集合中的put方法和remove方法的底層實現。
put
remove
關于如何進行ConcurrentHashMap集合源碼解析就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。