skiplist实现
skiplist跳跃表,是一种有序数据结构,通过在每个节点中维持多个指向其他节点的指针,来达到快速访问节点的目的,redis使用skiplist作为zsort的底层实现之一
结构很像树形结构
typedef struct zskiplistNode {
// 对象
sds ele;
// 分值
double score;
// 后退指针,从表尾向表头方向的访问及诶按
struct zskiplistNode *backward;
// 层 数组中可以包含多个元素,每个元素都包含一个指向其他节点的指针
struct zskiplistLevel {
// 前进指针,从表头向表尾方向访问节点
struct zskiplistNode *forward;
// 跨度,记录两个节点间的距离,跨度值是两个节点score的差值
unsigned long span;
} level[];
} zskiplistNode;
typedef struct zskiplist {
// 头尾节点
struct zskiplistNode *header, *tail;
// 跳跃表的长度
unsigned long length;
// 记录目前跳跃表的深度(表头节点的层数不计算在内)
int level;
} zskiplist;