zskiplist(跳跃表)
原理
zskiplist是一个有序的集合,为了解决其他链表的插入、删除效率低、查询元素需要循环遍历等缺点,redis就采用了一个特殊的数据结构zskiplist(跳跃表)。
它在性能上跟红黑树差不多, 同时又比红黑树的实现简单。在插入、删除、查询等操作上的时间复杂度为o(logn)。
分析
- 它通过在每个节点中维持多个指向其它节点的指针,从而达到快速访问节点的目的;
- Redis 只在两个地方用到了跳跃表,一个是实现有序集合健,另一个是在集群节点中用做内部数据结构,除此之外,跳跃表在 Redis 里没有其它用途;
- 一个常规的链表在做元素查找时,只能从头到尾的遍历来得到元素。时间复杂度为 O(n);
- zskiplist的头结点不是一个有效的节点,它有ZSKIPLIST_MAXLEVEL层(32层),每层的forward指向该层跳跃表的第一个节点,若没有则为null;
- redis限定了 ZSKIPLIST_P 抛硬币正面的概率为1/4
zskiplist 图解分析
zskiplist如何查找元素分析
加入我们想查找 9 这个元素,步骤如下: