算法對比
二叉樹
當我查找 8 的時候需要走五步
紅黑樹
當我查詢8的時候需要四次 相對于二叉樹有了一些優化 沒有無限延伸.紅黑樹的深度會很深(深度不可控制)
hash
數據量大的話
查詢很快(不能范圍查找)
BTree
查詢只需要查兩步就可以找到,缺點攜帶(data)擴大橫向減少縱向深度
ps:JAVA拿取數據一般是這樣的:java程序-->CPU--->內存---->硬盤,而內存與硬盤的交互是有大小限制的,是一頁數據4k左右,所以不能把所有數據都放在一個節點來獲取,一般來說節點會盡量預存4K容量。
B+Tree
BTree 變種B+Tree
ps:data不放在非葉子節點來增加度(小節點),一般會一百個以上使得深度是3~5,從而減少查詢次數。并且,葉子節點之間會有指針,數據又是遞增的,這使得我們范圍查找可以通過指針連接查找,而不再從上面節點往下一個個找。既減少了查詢次數,又提供了范圍查詢.