第一阶段阅读Redis的数据结构部分,基本位于如下文件中:
内存分配 zmalloc.c和zmalloc.h
动态字符串 sds.h和sds.c
双端链表adlist.c和adlist.h
字典 dict.h和dict.c
跳跃表 server.h文件里面关于zskiplist结构和zskiplistNode结构,以及t_zset.c中所有zsl开头的函数,比如 zslCreate、zslInsert、zslDeleteNode等等。
基数统计 hyperloglog.c 中的 hllhdr 结构, 以及所有以 hll 开头的函数
第二阶段 熟悉Redis的内存编码结构整数集合数据结构 intset.h和intset.c压缩列表数据结构 ziplist.h和ziplist.c
第三阶段 熟悉Redis数据类型的实现对象系统 object.c字符串键 t_string.c列表建 t_list.c散列键 t_hash.c集合键 t_set.c有序集合键 t_zset.c中除 zsl 开头的函数之外的所有函数HyperLogLog键 hyperloglog.c中所有以pf开头的函数
* object.c ✅
* t_string.c ✅
* t_list.c
* t_hash.c
* t_set.c
* t_zset.c
第四阶段 熟悉Redis数据库的实现数据库实现
* redis.h文件中的redisDb结构,以及db.c文件
* 通知功能 notify.cRDB
* 持久化 rdb.c
* AOF持久化 aof.c
* 以及一些独立功能模块的实现发布和订阅
* redis.h文件的pubsubPattern结构
* 以及pubsub.c文件事务
* redis.h文件的multiState结构以及multiCmd结构,
* multi.c文件
第五阶段 熟悉客户端和服务器端的代码实现事件处理模块 ae.c/ae_epoll.c/ae_evport.c/ae_kqueue.c/ae_select.c网路链接库 anet.c和networking.c服务器端 redis.c客户端 redis-cli.c这个时候可以阅读下面的独立功能模块的代码实现lua脚本 scripting.c慢查询 slowlog.c监视 monitor.c第六阶段 这一阶段主要是熟悉Redis多机部分的代码实现复制功能 replication.cRedis Sentinel sentinel.c集群 cluster.c
https://www.bilibili.com/video/BV1bo4y1Z7xf?p=4&spm_id_from=pageDriver
如果要改变原来的值,那么就传地址,如果只是对这个数据进行一个阐述,那么就传值。
* 传值: 字面值
* 传引用: 数据所在的地址,也就是所谓的指针
就算是传引用,在栈中的地址空间也是不一致的,也就是main中的*p和ff中的 p不是同一个地址,但是他们都引用了同一份地址空间。
* 具体值就用&曲地址
* 指针就直接传递 int* 其实就是一份数据,只不过这份数据是地址,&p则是取这个指针的地址,这个没必要, *p就是取地址指向的数据
mycodeschool
https://stackoverflow.com/questions/14388706/how-do-so-reuseaddr-and-so-reuseport-differ