闲聊
看了redis zset后,突然想写一篇跳跃表的文章。
说一说跳跃表,其实跳跃表的思想有点像二分法的思想,为什么不直接用二分呢,因为跳跃表一般处理的是链表而不是数组。如果是数组的话,只要维持有序,查的时候直接二分就行。二跳跃表要面对的一般是链表,链表不像数组内存地址连续,可以直接访问到想要的地方,链表的访问通常来讲是从头部开始遍历,或者尾部开始遍历。如果每找一个值都要一个一个查的话效率实在是太低,在面对大量的数据时有些力不从心。而跳跃表可以解决这个问题,虽说hashmap也可以解决这个问题,但是hashmap排序的话效果不是很好,而且重构成本也要更高。linkedhashmap确实是可以解决排序问题,但是维护的成本又变高了。估么redis设计的时候也是考虑了这些因素。
正题
思路
大致就是设计个节点,这个节点有上下左右四个指针,用于指向其他的节点。
大致就长成这个样子,直线代表指针,因为每一条都是双向的就不表明箭头了。
生成的时候先生成最下面的那一行,之后每隔一位上升一个节点,当然也可以随机上升,随机要好一些,一般都用随机