文档章节

redis 之 adlist

老汉-憨憨
 老汉-憨憨
发布于 2017/07/24 20:59
字数 669
阅读 7
收藏 0

digraph adlist {

    rankdir=LR;

    node [shape=record, style = filled, fillcolor = "#95BBE3"];

    edge [style = bold];

    list_node_1 [label = "<head>listNode |{<prev> prev| value|<next> next}", ];
    list_node_2 [label = "<head>listNode |{<prev> prev| value|<next> next}"];
    list_node_3 [label = "<head>listNode |{<prev> prev| value|<next> next}"];

    list_node_1:next -> list_node_2:head;
    list_node_2:next -> list_node_3:head;

    list_node_2:prev -> list_node_1:head;
    list_node_3:prev -> list_node_2:head;

    node [width=1.5, style = filled, fillcolor = "#A8E270"];
    list [label = "list |<head> head|<tail> tail|<dup> dup|<free> free|<match> match|<len> len"];

    list:tail -> list_node_3:head;
    list:head -> list_node_1:head;
}

这里主要是测试和学习使用了 adlist 的相关函数, 具体原理后面补充:

1.  拷贝 :

adlist.c  和 adlist.h  到一个单独的文件夹, 自己创建一个 main.c 的文件

# 我的目录文件结构
adlist  adlist.c  adlist.h  main.c

#adlist 是编译后生成的可执行文件
#adlist.c 是 redis 源码里面的 adlist.c 做了少许修改
#adlist.h 是 redis 源码里面的 adlist.h 没有做任何修改
#main.c 为测试代码程序

adlist.c 修改部分如下:

#include <stdlib.h>
#include "adlist.h"
//#include "zmalloc.h"  // 注释调该头文件

// 定义了下面的两个宏
#define zmalloc malloc
#define zfree free

这里不贴 adlist.c 和 adlist.h 文件的内容了, 具体可以从 redis 里面的源码获得。

2. 具体测试源码如下:

#include <stdio.h>
#include <stdlib.h>
#include "adlist.h"

char str[] = "ABCDEFGHIJKLMOPQRSTUVWXYZ";

int main(int argc, char *argv[])
{
    int alphLen = sizeof(str)/sizeof(char);
    list *lst = listCreate();
    if (lst == NULL) {
        printf("listCreate() error!\n");
        return -1;
    }
    
    int i = 0;
    for (i = 0; i < alphLen; i++) {
       lst = listAddNodeHead(lst, &str[i]);
    }

    listIter *item = listGetIterator(lst, AL_START_HEAD);
    listNode *node = NULL;
    while ((node = listNext(item)) != NULL) {
        char *p = listNodeValue(node);
        printf("%c ", (char)(*p));
    }
    printf("\n");

    
    listRewindTail(lst, item);
    while ((node = listNext(item)) != NULL) {
        char *p = listNodeValue(node);
        printf("%c ", (char)(*p));
    }
    printf("\n");
    
    listReleaseIterator(item);
    item = NULL;

    printf("------------------------------------------------\n");
    list *lstdup = listDup(lst);

    listIter *itemdup = listGetIterator(lstdup, AL_START_TAIL);
    listNode *nodedup = NULL;
    while ((nodedup = listNext(itemdup)) != NULL) {
        char *p = listNodeValue(nodedup);
        printf("%c ", (char)(*p));
    }
    printf("\n");
    
    listRewind(lstdup, itemdup);
    while ((nodedup = listNext(itemdup)) != NULL) {
        char *p = listNodeValue(nodedup);
        printf("%c ", (char)(*p));
    }
    printf("\n");
    listReleaseIterator(itemdup); 
    itemdup = NULL;

    printf("------------------------------------------------\n");
    for (i = 0; i < alphLen; i++)  {
        listNode *indexN = listIndex(lst, (long)(i));
        char *p = listNodeValue(indexN);
        printf("%d -> %c\n", i, (char)(*p));
    }

    printf("------------------------------------------------\n");
    listRotate(lst);
    listNode *index0 = listIndex(lst, (long)(0));
    char *p = listNodeValue(index0);
    printf("%d -> %c\n", 0, (char)(*p));

    printf("------------------------------------------------\n");
    listDelNode(lst, index0); 
    listIter it;
    listRewindTail(lst, &it);
    while ((node = listNext(&it)) != NULL) {
        char *p = listNodeValue(node);
        printf("%c ", (char)(*p));
    }
    printf("\n");
    printf("------------------------------------------------\n");
    
    listNode *index3 = listIndex(lst, (long)(3));
    lst = listInsertNode(lst, index3, &str[0], 1);
    listRewind(lst, &it);
    while ((node = listNext(&it)) != NULL) {
        char *p = listNodeValue(node);
        printf("%c ", (char)(*p));
    }
    printf("\n");
    printf("------------------------------------------------\n");
    
    
    listRelease(lst);
    listRelease(lstdup);
    return 0;
}


3. 编译:

gcc main.c adlist.c -o adlist

4. 输出:

./adlist 
 Z Y X W V U T S R Q P O M L K J I H G F E D C B A 
A B C D E F G H I J K L M O P Q R S T U V W X Y Z  
------------------------------------------------
A B C D E F G H I J K L M O P Q R S T U V W X Y Z  
 Z Y X W V U T S R Q P O M L K J I H G F E D C B A 
------------------------------------------------
0 -> 
1 -> Z
2 -> Y
3 -> X
4 -> W
5 -> V
6 -> U
7 -> T
8 -> S
9 -> R
10 -> Q
11 -> P
12 -> O
13 -> M
14 -> L
15 -> K
16 -> J
17 -> I
18 -> H
19 -> G
20 -> F
21 -> E
22 -> D
23 -> C
24 -> B
25 -> A
------------------------------------------------
0 -> A
------------------------------------------------
B C D E F G H I J K L M O P Q R S T U V W X Y Z  
------------------------------------------------
 Z Y X A W V U T S R Q P O M L K J I H G F E D C B 
------------------------------------------------

 

© 著作权归作者所有

共有 人打赏支持
老汉-憨憨
粉丝 18
博文 322
码字总数 68382
作品 0
深圳
程序员
CentOS 6.5 安装 Redis 执行 make #error "Newer version of jemalloc required"

CentOS 6.5 安装 Redis 执行 make #error "Newer version of jemalloc required" 根据你系统安装时或之后安装的选项的情况,可能在安装的过程中遇到不同的问题; 就像今天遇到的一台机器,安...

锅巴跑跑
2016/11/30
150
0
Redis源码安装 CentOS7

获取官方最新源码 官方下载 地址:http://redis.io/download 选择一个稳定版本下载,当前稳定版本3.0.6。 下载源码 cd /tmp wget http://download.redis.io/releases/redis-3.0.6.tar.gz 编译...

Corlang
2016/01/14
18
0
Redis源码分析(adlist)

源码版本: 源码位置: adlist.h : 数据结构定义。 adlist.c:函数功能实现。 一、adlist简介 Redis中的链表叫(A generic doubly linked list implementation 一个通用的双端链表实现),和普...

yangbodong22011
2017/11/08
0
0
redis数据结构之一:链表

链表提供了高效的节点重排能力,以及顺序性的节点访问方式,并且可以通过增删节点来灵活地调整链表的长度。redis提供五种数据结构:String、hash、list、set、sorted set。这五大数据类型底层...

mypsf
2016/10/24
171
0
redis3.2安装过程分享

转载自我要求索网 redis3.2安装过程分享 去 redis官网 下载对应的版本。下载地址:https://redis.io/download centos安装redis 下载redis-3.2.5.tar.gz 解压文件并进入解压后的目录 [root@lo...

求索路
2016/12/27
55
0

没有更多内容

加载失败,请刷新页面

加载更多

《Netkiller Java 手札》· 二进制文件操作大全

本文节选自《Netkiller Java 手札》 Netkiller Java 手札 Mr. Neo Chan, 陈景峯(BG7NYT) 中国广东省深圳市望海路半岛城邦三期 518067 +86 13113668890 <netkiller@msn.com> $Id: book.xml 6......

netkiller-
13分钟前
0
0
Fiddler Debugger post请求

常用的两种: 第一种默认的 对应URL为www 的要用请求头为:Content-Type: application/x-www-form-urlencoded 请求参数为 :param1=1234¶m2=12345 注:有些接口是指定用这种的第二方式并不...

轻量级赤影
20分钟前
1
0
如何搭建母婴亲子类知识社区

近期社交领域融资动作频繁,海尔高管、海尔医疗有限公司总裁管礼庆创办的母婴知识分享社区平台Alwayslove于上月获得700万天使轮融资。 Alwayslove是一个母婴知识分享社区平台,采用UGC模式,...

ThinkSNS账号
22分钟前
0
0
Android 自定义构建类型 BuildType

最近接触到自定义构建类型 BuildType,发现这一块有些地方稍不注意的话会被绕进去浪费点时间,既然我这边已经花费时间了,如果正好你也需要接触到 BuildType,也许接下来分享的 tips 可能会帮...

猴亮屏
24分钟前
1
0
美团点评基于 Flink 的实时数仓建设实践

引言 近些年,企业对数据服务实时化服务的需求日益增多。本文整理了常见实时数据组件的性能特点和适用场景,介绍了美团如何通过 Flink 引擎构建实时数据仓库,从而提供高效、稳健的实时数据服...

美团技术团队
27分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部