Redis資料類型之鏈表

來源:互聯網
上載者:User

標籤:redis   鏈表   

Redis資料類型之鏈錶鏈表的實現

redis的列表的底層實現就是一個雙鏈表,源碼在src下的adlist.h和adlist.c

鏈表的結點資料結構

    /*     * 雙端鏈表節點     */    typedef struct listNode {        // 前置節點        struct listNode *prev;        // 後置節點        struct listNode *next;        // 節點的值        void *value;    } listNode;

鏈表資料結構

/* * 雙端鏈表結構 */typedef struct list {    // 表前端節點    listNode *head;    // 表尾節點    listNode *tail;    // 節點值複製函數    void *(*dup)(void *ptr);    // 節點值釋放函數    void (*free)(void *ptr);    // 節點值對比函數    int (*match)(void *ptr, void *key);    // 鏈表所包含的節點數量    unsigned long len;} list;
鏈表的redis的具體功能
  1. 列表鍵
  2. 發布與訂閱
  3. 慢查詢
  4. 監視器
部分函數的時間複雜度
// 返回給定鏈表所包含的節點數量// T = O(1)#define listLength(l) ((l)->len)// 返回給定鏈表的表前端節點// T = O(1)#define listFirst(l) ((l)->head)// 返回給定鏈表的表尾節點// T = O(1)#define listLast(l) ((l)->tail)// 返回給定節點的前置節點// T = O(1)#define listPrevNode(n) ((n)->prev)// 返回給定節點的後置節點// T = O(1)#define listNextNode(n) ((n)->next)// 返回給定節點的值// T = O(1)#define listNodeValue(n) ((n)->value)// 將鏈表 l 的值複製函數設定為 m// T = O(1)#define listSetDupMethod(l,m) ((l)->dup = (m))// 將鏈表 l 的值釋放函數設定為 m// T = O(1)#define listSetFreeMethod(l,m) ((l)->free = (m))// 將鏈表的對比函數設定為 m// T = O(1)#define listSetMatchMethod(l,m) ((l)->match = (m))// 返回給定鏈表的值複製函數// T = O(1)#define listGetDupMethod(l) ((l)->dup)// 返回給定鏈表的值釋放函數// T = O(1)#define listGetFree(l) ((l)->free)// 返回給定鏈表的值對比函數// T = O(1)#define listGetMatchMethod(l) ((l)->match)
/* * 建立一個新的鏈表 * * 建立成功返回鏈表,失敗返回 NULL 。 * * T = O(1) */list *listCreate(void){    struct list *list;    // 分配記憶體    if ((list = zmalloc(sizeof(*list))) == NULL)        return NULL;    // 初始化屬性    list->head = list->tail = NULL;    list->len = 0;    list->dup = NULL;    list->free = NULL;    list->match = NULL;    return list;}

注意,這裡的分配 malloc函數,是自己實現的zmalloc

著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

Redis資料類型之鏈表

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.