redis底层数据结构之skiplist实现示例
作者:bug生产者
这篇文章主要为大家介绍了redis底层数据结构之skiplist实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
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;
以上就是redis底层数据结构之skiplist实现示例的详细内容,更多关于redis底层数据结构skiplist的资料请关注脚本之家其它相关文章!