Redis开源代码读书笔记九(Object模块)

2023-05-16

Object功能特性


==》支持REDIS_STRING、REDIS_LIST、REDIS_SET、REDIS_ZSET、REDIS_HASH对象类型

==》支持对象引用计数

==》支持对象内存优化

==》支持对象比较,复制,获取对象值等操作

==》支持LRU算法


/* Object types */
#define REDIS_STRING 0
#define REDIS_LIST 1
#define REDIS_SET 2
#define REDIS_ZSET 3
#define REDIS_HASH 4


Object类型和编码方式


==》REDIS_STRING, REDIS_ENCODING_EMBSTR
==》REDIS_STRING, REDIS_ENCODING_RAW
==》REDIS_STRING, REDIS_ENCODING_INT
==》REDIS_LIST, REDIS_ENCODING_LINKEDLIST
==》REDIS_LIST, REDIS_ENCODING_ZIPLIST
==》REDIS_SET,  REDIS_ENCODING_HT
==》REDIS_SET,  REDIS_ENCODING_INTSET
==》REDIS_HASH,  REDIS_ENCODING_ZIPLIST
==》REDIS_ZSET,  REDIS_ENCODING_SKIPLIST
==》REDIS_ZSET,  REDIS_ENCODING_ZIPLIST

/* Objects encoding. Some kind of objects like Strings and Hashes can be
 * internally represented in multiple ways. The 'encoding' field of the object
 * is set to one of this fields for this object. */
#define REDIS_ENCODING_RAW 0     /* Raw representation */
#define REDIS_ENCODING_INT 1     /* Encoded as integer */
#define REDIS_ENCODING_HT 2      /* Encoded as hash table */
#define REDIS_ENCODING_ZIPMAP 3  /* Encoded as zipmap */
#define REDIS_ENCODING_LINKEDLIST 4 /* Encoded as regular linked list */
#define REDIS_ENCODING_ZIPLIST 5 /* Encoded as ziplist */
#define REDIS_ENCODING_INTSET 6  /* Encoded as intset */
#define REDIS_ENCODING_SKIPLIST 7  /* Encoded as skiplist */
#define REDIS_ENCODING_EMBSTR 8  /* Embedded sds string encoding */


Object结构体

typedef struct redisObject {
    unsigned type:4;
    unsigned encoding:4;
    unsigned lru:REDIS_LRU_BITS; /* lru time (relative to server.lruclock) */
    int refcount;
    void *ptr;
} robj;

#define sdsEncodedObject(objptr) (objptr->encoding == REDIS_ENCODING_RAW || objptr->encoding == REDIS_ENCODING_EMBSTR)

从上述结构体按位构造的方式看,Redis程序是非常经济的一种对象模型,这也是内存数据库中操作大量对象所必须考虑的。


Object基本接口


5种基本对象内存释放接口

void freeStringObject(robj *o);
void freeListObject(robj *o);
void freeSetObject(robj *o);
void freeZsetObject(robj *o);
void freeHashObject(robj *o);

对象引用计数操作接口


2种不同入参的对象打包接口

void decrRefCount(robj *o);
void decrRefCountVoid(void *o);

增加对象引用计数

void incrRefCount(robj *o);

复位对象引用计数

robj *resetRefCount(robj *obj);

对象创建接口


robj *createObject(int type, void *ptr);
 --> REDIS_ENCODING_RAW, type
 
robj *createStringObject(char *ptr, size_t len);
 --> <REDIS_ENCODING_EMBSTR_SIZE_LIMIT> createEmbeddedStringObject
  --> REDIS_ENCODING_EMBSTR, REDIS_STRING
 --> <!REDIS_ENCODING_EMBSTR_SIZE_LIMIT> createRawStringObject
  --> REDIS_ENCODING_RAW, REDIS_STRING
 
robj *createRawStringObject(char *ptr, size_t len);
 --> REDIS_ENCODING_RAW, REDIS_STRING
 
robj *createEmbeddedStringObject(char *ptr, size_t len);
 --> REDIS_ENCODING_EMBSTR, REDIS_STRING

robj *createStringObjectFromLongLong(long long value);
 --> <0, REDIS_SHARED_INTEGERS> use shared.integers[]; REDIS_ENCODING_INT, REDIS_STRING
 --> <LONG_MIN, LONG_MAX> createObject, REDIS_ENCODING_INT, REDIS_STRING
 --> <LONG LONG> createObject,REDIS_ENCODING_RAW, REDIS_STRING

robj *createStringObjectFromLongDouble(long double value, int humanfriendly);
 --> createStringObject
  --> <REDIS_ENCODING_EMBSTR_SIZE_LIMIT> createEmbeddedStringObject
   --> REDIS_ENCODING_EMBSTR, REDIS_STRING
  --> <!REDIS_ENCODING_EMBSTR_SIZE_LIMIT> createRawStringObject
   --> REDIS_ENCODING_RAW, REDIS_STRING

robj *createListObject(void);
 --> listCreate
 --> createObject(REDIS_LIST, ...)
 --> REDIS_ENCODING_LINKEDLIST
 --> listSetFreeMethod(l,decrRefCountVoid)

robj *createZiplistObject(void);
 --> ziplistNew
 --> createObject(REDIS_LIST, ...)
 --> REDIS_ENCODING_ZIPLIST

robj *createSetObject(void);
 --> dictCreate
 --> createObject(REDIS_SET, ...)
 --> REDIS_ENCODING_HT

robj *createIntsetObject(void);
 --> intsetNew
 --> createObject(REDIS_SET, ...)
 --> REDIS_ENCODING_INTSET

robj *createHashObject(void);
 --> ziplistNew
 --> createObject(REDIS_HASH, ...)
 --> REDIS_ENCODING_ZIPLIST

robj *createZsetObject(void);
 --> dictCreate
 --> zslCreate
 --> createObject(REDIS_ZSET, ...)
 --> REDIS_ENCODING_SKIPLIST

robj *createZsetZiplistObject(void);
 --> ziplistNew
 --> createObject(REDIS_ZSET,...)
 --> REDIS_ENCODING_ZIPLIST
 


对象操作接口


复制字符串对象
robj *dupStringObject(robj *o);

判断robj是否是longlong对象,并反馈value
int isObjectRepresentableAsLongLong(robj *o, long long *llongval);

判断对象是否可以压缩空间,如果无法节省空间返回原对象
robj *tryObjectEncoding(robj *o);

对robj进行解码,如果无法解码则增加引用计数后返回
robj *getDecodedObject(robj *o);

获取当前对象长度
size_t stringObjectLen(robj *o);

获取longlong值
int getLongLongFromObject(robj *o, long long *target);

获取longdouble值
int getLongDoubleFromObject(robj *o, long double *target);

翻译编码方式
char *strEncoding(int encoding);

二进制方式比较两个字符串对象
int compareStringObjects(robj *a, robj *b);
 --> compareStringObjectsWithFlags(a,b,REDIS_COMPARE_BINARY)

采用目前区域的字符排列次序来比较字符串
int collateStringObjects(robj *a, robj *b);
 --> compareStringObjectsWithFlags(a,b,REDIS_COMPARE_COLL)

字符串对象对比,对compareStringObjects进行优化

int equalStringObjects(robj *a, robj *b);


获取LRU clock,用于LRU算法

unsigned long long estimateObjectIdleTime(robj *o);



redis客户端连接操作(略)


int checkType(redisClient *c, robj *o, int type);

int getLongFromObjectOrReply(redisClient *c, robj *o, long *target, const char *msg);

int getLongLongFromObjectOrReply(redisClient *c, robj *o, long long *target, const char *msg);

int getDoubleFromObjectOrReply(redisClient *c, robj *o, double *target, const char *msg);

int getLongDoubleFromObjectOrReply(redisClient *c, robj *o, long double *target, const char *msg);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Redis开源代码读书笔记九(Object模块) 的相关文章

  • 关于【无人驾驶航空器飞行管理暂行条例】对航模的一些信息讨论&汇总

    关于 无人驾驶航空器飞行管理暂行条例 对航模的一些信息讨论 amp 汇总 1 源由2 讨论3 理解3 1 关于 管理对象 的理解3 2 关于 模型航空器管理规则 的理解3 3 关于 模型航空器 的理解3 4 关于 安全 的理解 4 参考资料
  • ArduPilot Kakute F7 AIO DIYF450 without GPS配置

    ArduPilot Kakute F7 AIO DIYF450 without GPS配置 1 源由2 配置2 1 Kakute F7 AIO相关配置2 1 1 串口规划2 1 2 电传配置2 1 3 GPS配置2 1 4 CRSF接收机配
  • ArduPilot开源飞控系统之简单介绍

    ArduPilot开源飞控系统之简单介绍 1 源由2 了解 amp 阅读2 1 ArduPilot历史2 2 关于GPLv32 3 ArduPilot系统组成2 4 ArduPilot代码结构 3 后续3 1 DIY F4503 2 软件设
  • ArduPilot Kakute F7 AIO DIYF450 之GPS配置

    ArduPilot Kakute F7 AIO DIYF450 之GPS配置 1 源由2 步骤2 1 模块预测试2 2 物理连接2 3 UART配置2 4 Compass使能2 5 GPS使能2 6 校准Compass 3 GPS amp
  • 关于CSDN文章内嵌视频自动播放问题

    关于CSDN文章内嵌视频自动播放问题 1 源由2 分析3 反馈4 沟通5 总结6 附录 Firefox配置7 附录 Microsoft Edge配置 1 源由 这个问题是4月初发现的 xff0c 主要现象就是页面上的视频一起自动播放了 鉴于
  • 关于FPV图传系统时延讨论

    关于FPV图传系统时延讨论 1 源由2 时延测试方法3 时延测试资料4 关于模拟图传5 关于FPV时延感受5 1 静态时延5 2 动态时延 6 参考资料7 附录7 1 When is 120fps NOT 120fps DJI O3 Air
  • ArduPilot之开源代码框架

    ArduPilot之开源代码框架 1 系统框架2 工程框架2 1 工程目录2 2 代码组成2 3 运行流程 4 硬件传感器总线4 1 I2C4 2 SPI4 3 UART4 4 CAN 5 软件设计概念6 总结7 参考资料 在研读ArduP
  • Charles电脑配置和手机配置【超详细,iOS和安卓】

    1 xff0c 电脑安装charles charles的安装非常简单 xff0c 直接通过charles官网安装最新版即可 Charles 是收费软件 xff0c 可以免费试用 30 天 试用期过后 xff0c 未付费的用户仍然可以继续使用
  • vmmem内存占用高

    文章目录 前言通过 wslconfig限制其内存使用 前言 什么时vmmem进程 vmmem进程时在使用vmware时的进程 xff0c 内存占用非常高 我是在使用docker时遇到的这个进程 通过 wslconfig限制其内存使用 这个方
  • QGroundControl之安装调试

    QGroundControl之安装调试 1 源由2 问题汇总2 1 摄像头播放问题2 2 Windows电脑录像和拍照保存位置2 3 Android设备录像和拍照保存位置 3 打包资料4 附录 QGroundControl Video St
  • ArduPilot之posHold&RTL实测

    ArduPilot之posHold amp RTL实测 1 源由2 模式配置3 测试步骤4 飞行实测5 总结6 参考资料7 附录 关于QGC 暂不支持MAVLink2 signing Protocol问题7 1 问题描述7 2 硬件配置7
  • ArduPilot之开源代码Library&Sketches设计

    ArduPilot之开源代码Library amp Sketches设计 1 简介1 1 Core libraries1 2 Sensor libraries1 3 Other libraries 2 源由3 Library Sketche
  • ArduPilot之开源代码Sensor Drivers设计

    ArduPilot之开源代码Sensor Drivers设计 1 源由2 Sensor Drivers设计2 1 front end back end分层2 2 设计思想分析 3 实例理解3 1 驱动初始化3 2 业务应用代码3 3 fro
  • ArduPilot之开源代码基础知识&Threading概念

    ArduPilot之开源代码基础知识 amp Threading概念 1 源由2 基础知识2 1 The timer callbacks2 2 HAL specific threads2 2 1 AP HAL ChibiOS2 2 2 AP
  • ArduPilot之GPS Glitch问题&M8N模块配置

    ArduPilot之GPS Glitch问题 amp M8N模块配置 1 源由2 现象3 视频分析3 1 配置 xff08 不理想 xff09 3 2 配置优化3 3 优化配置 43 短时间 43 3D Lock 43 Glitch3 4
  • BetaFlight统一硬件配置文件研读

    BetaFlight统一硬件配置文件研读 1 源由2 分析2 1 硬件SOC2 2 统一配置文件2 3 cli命令2 4 板级配置主要命令2 4 1 board name2 4 2 manufacturer id2 4 3 resource
  • BetaFlight统一硬件配置文件研读之timer命令

    BetaFlight统一硬件配置文件研读之timer命令 1 源由2 代码分析3 实例分析4 配置情况4 1 AFn配置查表4 2 timer4 3 timer show4 4 timer pin list 5 参考资料 统一硬件配置文件的
  • 自制肥鲨HDO2电源之功率问题

    自制肥鲨HDO2电源之功率问题 1 源由2 分析2 1 电压检测2 2 功率检测 3 思考4 验证4 1 PH50 10400mAh充电宝供电4 2 PH80 20000mAh充电宝供电4 3 总结 5 参考资料 1 源由 前端时间因为肥鲨
  • BetaFlight统一硬件配置文件研读之serial命令

    BetaFlight统一硬件配置文件研读之serial命令 1 源由2 代码分析3 实例分析4 配置情况5 参考资料 统一硬件配置文件的设计是一种非常好的设计模式 xff0c 可以将硬件和软件的工作进行解耦 1 源由 cli命令中seria
  • Mac配置环境变量后所有命令失效(多条解决方案)

    目录 1 xff0c 首先让命令暂时生效 xff0c 但关窗口后不生效了就 2 xff0c 该操作会清空之前配置的bash profile xff0c 来使命令生效 3 xff0c 该操作可保存原来的bash profile的配置 xff0

随机推荐

  • BetaFlight统一硬件配置文件研读之set命令

    BetaFlight统一硬件配置文件研读之set命令 1 源由2 代码分析3 实例分析4 配置情况4 1 set4 2 set parameter name4 3 set parameter name value 5 参考资料 统一硬件配置
  • BetaFlight统一硬件配置文件研读之feature命令

    BetaFlight统一硬件配置文件研读之feature命令 1 源由2 代码分析3 实例分析4 配置情况4 1 feature4 2 feature list4 3 feature feature name4 4 feature feat
  • BetaFlight统一硬件配置文件研读之dma命令

    BetaFlight统一硬件配置文件研读之dma命令 1 源由2 代码分析2 1 cliDma2 2 showDma2 3 cliDmaopt 3 实例分析4 配置情况4 1 dma4 2 dma show4 3 dma device li
  • BetaFlight统一硬件AOCODARC H7DUAL配置文件讨论

    BetaFlight统一硬件AOCODARC H7DUAL配置文件讨论 1 源由2 Review配置3 分析整理3 1 生产商信息3 2 磁力计3 3 气压计3 4 陀螺仪3 5 串口RxTx3 6 板载Flash3 7 模拟OSD MAX
  • BetaFlight Mark4之“妖怪”声音

    BetaFlight Mark4之 妖怪 声音 1 源由2 分析3 数据3 1 配置一3 1 1 妖怪 声音 黑匣子分析 3 2 配置二3 2 1 仅配置调整 xff08 其他不变 xff09 3 2 2 配置调整 43 整体螺丝锁紧 4
  • FileZilla 安装使用指南

    FileZilla是一个FTP开源项目 xff0c 这里介绍下FTP客户端的安装和使用 61 FileZilla客户端下载 61 FileZilla 最新版本下载 首先 xff0c 可以在FileZilla官方网站上找到客户端下载链接 xf
  • Cygwin本地安装

    61 61 61 说明 61 61 61 当前Cygwin的版本是在线安装之后 xff0c 保存在本地后形成的本地版本 当前操作系统是Windows 8 xff0c 本教程仅提供安装Cygwin的方法 61 61 61 安装步骤 61 61
  • win7自动登录进入桌面系统的配置方式

    Win7直接自动进入桌面的方法 61 61 步骤一 xff1a 在打开命令编辑框 xff0c 键入控制命令 61 61 先在Win7中按 Win 43 R 键打开运行对话框或者是点 开始 菜单 xff08 如下图 xff09 xff0c 在
  • VC6下采用ShellExecuteEx提升管理员权限

    bool IsOsVersionVistaOrGreater OSVERSIONINFOEX ovex CHAR szVersionInfo 1024 szVersionInfo 61 39 x00 39 设置参数的大小 xff0c 调用并
  • Redis开源代码读书笔记一(介绍)

    本人一直是C语言走过来的 xff0c 最近闲来无事 xff0c 学习和研究下Redis开源代码 xff0c 并计划随着代码的深入理解做个简单的读书笔记 xff0c 希望和大家一起学习和探讨 当然第一篇仅仅是做个介绍啦 xff0c 可能更多的
  • karate参数使用和设置debug超长延时

    常用参数 1 patch 和 put patch xff1a 只上传其中一部分参数 xff0c 不幂等put xff1a 幂等 xff0c 要上传完整参数体 2 xff0c And Param req 和 And request req P
  • Redis开源代码读书笔记二(源代码及工程结构)

    Redis是一款采用C语言开发的 lt Key Value gt 内存数据存储系统 今天主要3 0 7版本的的源代码和工程结构 xff0c 并初步分解一下Redis内部开发模块及组成 从Makefile文件和其执行过程及输出日志 xff0c
  • Redis开源代码读书笔记三(zmalloc模块)

    模块特性 61 61 支持内存分配配置 61 61 支持线程安全 61 61 支持内存分配失败异常处理流程自定义 61 61 支持字符串复制操作 61 61 支持当前内存大小占用记录 61 61 支持内存碎片化计算 61 61 支持系统内存
  • Redis开源代码读书笔记四(redis-server主程序, redis.c)

    Redis工程代码从 Redis开源代码读书笔记二 xff08 源代码及工程结构 xff09 中可以看出 xff0c 是非常出色的模块化代码 因此 xff0c 从敏捷的角度看 xff0c 是非常易于阅读和增量开发的 由于琐碎时间的原因 xf
  • Redis开源代码读书笔记五(adlist模块)

    adlist功能特性 61 61 支持双链表节点操作 ins del add create dup release search rotate index 61 61 支持双链表iter操作 get release rewind next
  • Redis开源代码读书笔记六(sds模块)

    SDS是一个动态字符串库 xff0c 主要用于字符串操作 SDS模块功能特性 61 61 支持字符串基本操作 new free dup cpy append add trim cmp range split join lower upper
  • Redis开源代码读书笔记零(Ubuntu14.04 64位安装)

    Redis代码可以在Linux OSX OpenBSD NetBSD FreeBSD系统上进行部署 xff0c 并且支持大小端CPU类型 学习环境采用了一台Ubuntu14 04 64位的系统 xff0c 所有代码的学习是基于redis 3
  • Redis开源代码读书笔记七(ae模块)

    AE模块是一个简单的文件事件和定时器事件的处理模块 AE模块功能 61 61 支持事件ms级时间粒度 61 61 支持定时器事件处理 单链表 支持删除定时器事件操作 支持事件处理流程及私有数据 61 61 支持文件事件处理 数组 支持文件读
  • Redis开源代码读书笔记八(anet模块)

    anet模块主要为对通信API的抽象和封装 anet功能特性 61 61 支持Unix Domain Socket服务 61 61 支持V4 V6版本的Tcp Socket服务 61 61 支持阻塞及非阻塞式TCP连接 61 61 支持Tc
  • Redis开源代码读书笔记九(Object模块)

    Object功能特性 61 61 支持REDIS STRING REDIS LIST REDIS SET REDIS ZSET REDIS HASH对象类型 61 61 支持对象引用计数 61 61 支持对象内存优化 61 61 支持对象比