redis中的intset集合源码阅读探究;基于7.0+版本

news2024/11/18 23:30:17

1丶什么是intset

Redis 中的 intset(整数集合)是一种高效的数据结构选择。Intset 具有紧凑的内存布局和快速的插入、删除和查找操作,适用于存储大量整数,并且能够节省内存空间。

2丶先说优点

内存布局:Intset 的内存布局非常紧凑。它使用连续的内存块存储整数,并且根据实际存储的整数大小选择适当的编码方式,以节省内存空间。

编码方式:Intset 使用不同的编码方式来存储整数,包括 INT16、INT32 和 INT64。它根据存储的整数值的范围选择最小的编码方式,以便节省内存。编码方式会根据需要进行动态调整。

快速的查找: 因为intset是有序数组,支持logn的查找复杂度. 2分大法.

3丶局限性

Intset 只能存储整数类型的数据,不支持其他数据类型。

频繁的插入和删除 中间元素; 不是最小最大元素.

4丶个人理解的使用场景

1丶整数. 2丶增删改 比较少.(或者插入有序的整数) 3丶主要用于查询 4丶空间资源紧缺
默认在512长度的整数内是使用该结构的,看读者的需求,如果是大量整数的存储且主要用于查询,可以调大这个配置.
redis.config中配置: set-max-intset-entries = 你需要的

5丶源码分析

1丶先看头文件.

在这里插入图片描述
###丶2丶点进创建的方法.
这个没啥难度,就是初始化,分配内存,设置默认值.此时可以知道,他默认内存只是 encoding字段和length字段占用的空间大小.所以比dict结构省很多空间,键值对啊?扩展保留的空间啊,等等.

intset *intsetNew(void) {
	//分配内存
    intset *is = zmalloc(sizeof(intset));
    //指定编码方式;  默认使用了 INTSET_ENC_INT16; 即有符号的
    is->encoding = intrev32ifbe(INTSET_ENC_INT16);
    is->length = 0;
    return is;
}

3丶插入方法

intset *intsetAdd(intset *is, int64_t value, uint8_t *success) {
    //拿到当前元素的编码方式;方法直接放这里了,省的看.就是一些常量的大小比较.
    //    static uint8_t _intsetValueEncoding(int64_t v) {
	//        if (v < INT32_MIN || v > INT32_MAX)
	//            return INTSET_ENC_INT64;
	//        else if (v < INT16_MIN || v > INT16_MAX)
	//            return INTSET_ENC_INT32;
	//        else
	//            return INTSET_ENC_INT16;
	//    }
    uint8_t valenc = _intsetValueEncoding(value);
    //插入的位置.position
    uint32_t pos;
    if (success) *success = 1;
    //如果插入的大于
    if (valenc > intrev32ifbe(is->encoding)) {
        /* This always succeeds, so we don't need to curry *success. */
        return intsetUpgradeAndAdd(is,value);
    } else {
        /* Abort if the value is already present in the set.
         * This call will populate "pos" with the right position to insert
         * the value when it cannot be found. */
        if (intsetSearch(is,value,&pos)) {
            if (success) *success = 0;
            return is;
        }

        is = intsetResize(is,intrev32ifbe(is->length)+1);
        if (pos < intrev32ifbe(is->length)) intsetMoveTail(is,pos,pos+1);
    }

    _intsetSet(is,pos,value);
    is->length = intrev32ifbe(intrev32ifbe(is->length)+1);
    return is;
}

暂定后续更新

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/641555.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vue-element-admin项目-Host key verification failed.-已解决

在网上下载的element-admin项目&#xff0c;install的时候一直报错Host key verification failed&#xff0c; 实测好用&#xff01;&#xff01;&#xff01;已解决 报错问题&#xff1a;上面写到主机密钥验证失败&#xff0c;无法从远程仓库拉取。说明我们需要生成一个新的密…

基于JAVA SSM框架和jsp的学生宿舍管理系统

计算机信息技术和当前办公的信息化、自动化、网络化极大地改变了高校、企事业单位的信息管理方式&#xff0c;高效、快速、准确的信息管理已成为各行业现代管理的重要手段。目前宿舍管理人员普遍年龄偏大&#xff0c;使用笔录工作量大&#xff0c;管理难度大&#xff0c;利用学…

如何安装官网最新版Android Studio

1、进入android studio官网&#xff0c;点击下载。 2、下滑查看协议&#xff0c;勾选同意按钮&#xff0c;点击下载。 3、打开安装程序&#xff0c;点击Next。 4、选择虚拟机&#xff0c;点击Next。 5、选择安装路径&#xff0c;点击Next。 6、点击Install。 5、等待安装…

Kafka学习---2、kafka生产者、异步和同步发送API、分区、生产经验

1、kafka生产者 1.1 生产者消息发送流程 1.1.1 发送原理 在消息发生的过程中&#xff0c;设计到了两个线程——main线程和Sender线程。在main线程中创建了一个双端队列RecordAccumulator。main线程将消息发给RecordAccumulator&#xff0c;Sender线程不断从RecordAccumulato…

AST环境安装及使用

1.环境安装 AST在线解析网站&#xff1a;https://astexplorer.net/ 可以看出Parser用的是 babel/parser ,这是一个目前最流行的JS语法编译器Babel的Node.js包。 Babel是编译器。babel/parser是Babel中的解析器&#xff0c;用于解析JS语言&#xff0c;本质也是一个Node.js包 …

wenda+fess问答系统

1 安装conda 2 创建环境 conda activate --name wenda python3.8 3 安装依赖工具包 pip install -r requirements/requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple pip install torch BeautifulSoup4 torchvision torchaudio pdfminer.six -i https://pypi.t…

降维和特征选择的对比

降维? 降低数据集中特征的维数,同时保持尽可能多的信息的技术被称为降维。它是机器学习和数据挖掘中常用的技术,可以最大限度地降低数据复杂性并提高模型性能。 降维可以通过多种方式实现,包括: 主成分分析 (PCA):PCA 是一种统计方法,可识别一组不相关的变量,将原始变…

华为OD机试真题B卷 JavaScript实现【报文重排序】,附详细解题思路

一、题目描述 对报文进行重传和重排序是常用的可靠性机制&#xff0c;重传缓冲区内有一定数量的子报文&#xff0c;每个子报文在原始报文中的顺序已知&#xff0c;现在需要恢复出原始报文。 二、输入描述 输入第一行为N&#xff0c;表示子报文的个数&#xff0c;0 < N &l…

chatgpt赋能python:Python建模:从入门到精通

Python建模&#xff1a;从入门到精通 Python是一种高级编程语言&#xff0c;已经成为了机器学习和数据科学领域的事实标准。因为Python比其他语言更容易学习和上手&#xff0c;所以它是入门级开发人员和数据科学家的首选语言。 在本文中&#xff0c;我们将介绍Python建模的基…

深入解析IT专业分类、方向及就业前景:高考毕业生如何选择适合自己的IT专业?重点探索近年来人工智能专业发展及人才需求

目录 一、IT专业的就业前景和发展趋势二、了解IT专业的分类和方向三、你对本专业的看法和感想四、本专业对人能力素养的要求五、建议和思考其它资料下载 当今社会&#xff0c;信息技术行业以其迅猛的发展和无限的潜力成为了吸引无数年轻人的热门选择。特别是对于高考毕业生来说…

10.面向对象编程(高级部分)|Java学习笔记

文章目录 类变量和类方法类变量类变量使用注意事项和细节 类方法类方法使用注意事项和细节 理解 main 方法语法代码块代码块使用注意事项和细节讨论 单例设计模式单例模式应用实例饿汉式 VS 懒汉式 final 关键字final 使用注意事项和细节 抽象类抽象类的介绍抽象类使用的注意事…

Vue中如何进行文件压缩与解压缩?

Vue中如何进行文件压缩与解压缩&#xff1f; 在前端开发中&#xff0c;文件的压缩和解压缩是经常需要用到的功能。尤其是在需要上传和下载文件的场景下&#xff0c;文件压缩可以减小文件大小&#xff0c;加快文件传输速度&#xff0c;提高用户体验。本文将介绍在Vue项目中如何…

纷享销客王亚辉:聚焦终端,打造医疗健康行业管理新高度

1.医疗健康行业持续增长的关键 是数字化经营客户价值 随着生活水平和生活质量的不断提高&#xff0c;人们的医疗健康意识日渐增强&#xff0c;对医疗健康的需求越来越强烈&#xff1b;同时&#xff0c;国家政策的扶持再加上人口老龄化进程加快&#xff0c;进一步推动着医疗健…

【spring源码系列-05】refresh中prepareRefresh方法的执行流程

Spring源码系列整体栏目 内容链接地址【一】spring源码整体概述https://blog.csdn.net/zhenghuishengq/article/details/130940885【二】通过refresh方法剖析IOC的整体流程https://blog.csdn.net/zhenghuishengq/article/details/131003428【三】xml配置文件启动spring时refres…

003、体系结构之TiKV持久化

TiKV架构和作用 数据持久化分布式一致性MVCC分布式事务Coprocessor coprocessor : 协同处理器。 可以将一些SQL计算交给TiKV处理。不需要将TiKV所有数据通过网络发送给TiDB Server RocksDB 任何持久化的存储引擎&#xff0c;数据终归要保存在磁盘上&#xff0c;TiKV 也不例外…

NeRF in the wild 论文解读与公式推导

NeRF in the Wild: Neural Radiance Fields for Unconstrained Photo Collections 论文&#xff1a;https://openaccess.thecvf.com/content/CVPR2021/papers/Martin-Brualla_NeRF_in_the_Wild_Neural_Radiance_Fields_for_Unconstrained_Photo_CVPR_2021_paper.pdfhttps://op…

不同等级的Pads工程师,薪资差距有多大?

作为一种广泛应用在PCB设计的EDA工具&#xff0c;Pads软件在中国的电子设计行业中有着重要地位&#xff0c;尤其是不同等级的Pads工程师&#xff0c;在薪资、工作范围等有很大的差异&#xff0c;本文将从中国出发&#xff0c;多方面分析对比不同等级的Pads工程师&#xff0c;希…

监控、审计和运行时安全

监控、审计和运行时安全 目录 文章目录 监控、审计和运行时安全目录1、分析容器系统调用&#xff1a;SysdigSysdig介绍安装sysdigsysdig常用参数sysdig常用命令Chisels(实用的工具箱)其它命令 2、监控容器运行时&#xff1a;FalcoFalco介绍Falco架构安装falco自定义扩展规则文件…

ElasticSearch(ES)介绍

前言 为什么学习ElasticSearch&#xff1f; 1、ElasticSearch具备非常强的大数据分析能力。虽然Hadoop也可以做大数据分析&#xff0c;但是ElasticSearch的分析能力非常高&#xff0c;具备Hadoop不具备的能力。比如有时候用Hadoop分析一个结果&#xff0c;可能等待的时间比较…

免费获取程序员好书,这个宝藏网站等你来挖!

今天给大家分享一个免费的程序员、IT、互联网资源的​免费书籍网站。​ 书籍类型涵盖了Vue、CSS、小程序等前端语言、框架&#xff1b;.NET、JAVA、Go等后端语言&#xff1b;Android、IOS、Flutter等移动语言&#xff1b;数据库、云计算大数据、网络系统运维、UI美工设计、游戏…