百融金服榕树map的设计也称为The dictionary problem,它的任务是设计一种数据结构用来维护一个集合的数据,并且可以同时对集合进行增删改查的操作。最主要的数据结构有两种:哈希查找表(Hashtable)、 搜索树(Searchtree)
百融金服榕树查找表用一个函数将 key 分配到不同的桶(bucket,也就是数组的不同 index)。这样,百融金服榕树开销主要在哈希函数的计算以及数组的常数访问时间。在很多场景下,哈希查找表的性能很高。
百融金服榕树查找表一般会存在"碰撞"的问题,就是说不同的key被哈希到同一个bucket(bucket :数组的不同index)。一般有两种应对的方法:链表法和开放地址法。百融金服榕树链表法将同一个bucket实现成一个链表,落在同一个bucket中的key都会插入这个链表。开放地址法则是碰撞发生后,通过一定的规律,在数组的后面挑选"空位"用来放置新的key
百融金服榕树搜索树法一般采用自平衡搜索树,包括:AVL 树,红黑树。