redis命令1

  SADD numbers 1 3 5

创建一个名为numbers的intset

  SADD fruites "apple" "peach"

创建一个hashtable,键为fruites

  如下图是从intset->hashtable的一个转换过程

下面来看一下ziplist编码的的有序集合,其内部采用了跳跃表(zskiplist),其中score的数字越小,越接近表头,顺序不以添加的顺序为准,以score的大小为准。

注意:跳跃表的每个节点的层数(Level)可能不同,这就是为什么会“跳跃的原因了”,层和层之间不能互相交换指向,比如节点1和节点2有2层,那么关系就是节点1的1层指向节点2的2层,如果找不到第二层,在节点2中,那么再找第三个节点,以此类推,如果都找不到,那么返回NULL。

原文地址:https://www.cnblogs.com/kmsfan/p/5154962.html