Redis(一)之 struct sdshdr *sh = (void*) (s-(sizeof(struct sdshdr)))讲解

看Redis的源码的时候,我有点好奇,不知道

 struct sdshdr *sh = (void*) (s-(sizeof(struct sdshdr)))

是啥意思,所以就了解了下,首先我们看sdshdr的结构体

/*
 * 类型别名,用于指向 sdshdr 的 buf 属性
 */
typedef char *sds;

/*
 * 保存字符串对象的结构
 */
struct sdshdr {
    
    // buf 中已占用空间的长度
    int len;

    // buf 中剩余可用空间的长度
    int free;

    // 数据空间
    char buf[];
};

首先我们得知道

char buf[]

这个数组没有大小,是所谓的柔性数组,是不占据内存大小的,所以sizeof(struct sdshdr)为8。
还有sds数据类型为char*类型,从定义可以看出,然后我们再来看这个结构体的初始化

sds sdsnewlen(const void *init, size_t initlen) {

    struct sdshdr *sh;

    // 根据是否有初始化内容,选择适当的内存分配方式
    // T = O(N)
    if (init) {
        // zmalloc 不初始化所分配的内存
        sh = zmalloc(sizeof(struct sdshdr)+initlen+1);
    } else {
        // zcalloc 将分配的内存全部初始化为 0
        sh = zcalloc(sizeof(struct sdshdr)+initlen+1);
Redis中的链表实现是双向链表。每个节点包括个指向前个节点的指针(prev)和个指向后个节点的指针(next)。这种双向链表的结构使得在插入、删除和访问节点时具有高效性能。 Redis中链表的定义如下: ```c typedef struct listNode { struct listNode *prev; struct listNode *next; void *value; } listNode; typedef struct list { listNode *head; listNode *tail; unsigned long len; void *(*dup)(void *ptr); void (*free)(void *ptr); int (*match)(void *ptr, void *key); } list; ``` 链表通过head指针指向第个节点,通过tail指针指向最后个节点。len表示链表的长度。 在Redis中,链表常用于实现列表(list)数据结构,并提供了丰富的操作函数,如插入、删除、遍历等。 例如,向链表中插入个新节点的操作可以通过以下代码实现: ```c listNode *listInsertNode(list *list, listNode *old_node, void *value, int after) { listNode *node = malloc(sizeof(*node)); if (node == NULL) return NULL; node->value = value; if (after) { node->prev = old_node; node->next = old_node->next; if (list->tail == old_node) list->tail = node; } else { node->next = old_node; node->prev = old_node->prev; if (list->head == old_node) list->head = node; } if (node->prev != NULL) node->prev->next = node; if (node->next != NULL) node->next->prev = node; list->len++; return node; } ``` 这段代码会在old_node节点之前或之后插入个新节点,并更新相应的指针和链表长度。 除了基本的链表操作外,Redis的链表还支持索引操作、范围操作等高级功能,使得链表更加灵活和强大。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值