Redis-压缩表-ziplistPrev详解

/* 返回p指向的结点的前置结点
如果p指向的压缩表是空表,返回NULL,
如果p指向压缩表的表头结点,返回NULL */
unsigned char *ziplistPrev(unsigned char *zl, unsigned char *p) {
    zlentry entry;

    /*p指向压缩表的表尾,则p的前置结点就是压缩表的最后一个结点 */
    if (p[0] == ZIP_END) {
        p = ZIPLIST_ENTRY_TAIL(zl); /* 获得压缩表的最后一个结点*/
        /* 如果获得的最后一个结点指向压缩表的表尾,说明压缩表为空,返回NULL,否则返回p */
        return (p[0] == ZIP_END) ? NULL : p;

    } else if (p == ZIPLIST_ENTRY_HEAD(zl)) { /* 如果p指向压缩表的第一个结点,则前置结点为空 */
        return NULL;

    } else {
        entry = zipEntry(p); /* 获得p指向的结点信息 */
        assert(entry.prevrawlen > 0); /* p的前置结点的长度大于0,即p有前置结点,程序继续,否则程序中断 */
        return p - entry.prevrawlen; /* 返回p指向的前置结点的指针 */
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值