1. JDK1.8取消了segment數組,直接用table保存數據,鎖的粒度更小,減小併發衝突的機率。數組
2. 1.8存儲數據時採用了鏈表+紅黑樹的形式,純鏈表的形式時間複雜度爲O(n),紅黑樹則爲O(logn),性能提高很大。何時鏈表轉紅黑樹?當key值相等的元素造成的鏈表中元素個數超過8個的時候。數據結構
3. 1.8的實現下降鎖的粒度,JDK1.7版本鎖的粒度是基於Segment的,包含多個HashEntry,而JDK1.8鎖的粒度就是HashEntry(首節點)併發
4. 1.8版本的數據結構變得更加簡單,使得操做也更加清晰流暢,由於已經使用synchronized來進行同步,因此不須要分段鎖的概念,也就不須要Segment這種數據結構了,因爲粒度的下降,實現的複雜度也增長了性能
5. 1.8使用紅黑樹來優化鏈表,基於長度很長的鏈表的遍歷是一個很漫長的過程,而紅黑樹的遍歷效率是很快的,代替必定閾值的鏈表,這樣造成一個最佳拍檔優化