Redis学习之旅 位图(BitMap)

Redis学习之旅 位图(BitMap)

单独给位图开一章,是因为这块的东西确实玩法众多,面试也常常遇到,干脆将其拆分为独立的一章

Redis BIT相关命令

BITCOUNT

从字面意思上来看,bitcount翻译过来叫位统计,那么统计的是什么呢?,其实是01串中1的个数

  • OK,这不简单么,我知道了,字符串1 BITCOUNT的结果肯定是1,因为1的二进制是 0000 0001嘛,我们看下结果
    在这里插入图片描述

我了个大擦,怎么会是3?,这就又回到我们在String篇里提到的一个概念,Redis String类型的数据,都是按一个字节一个字节来保存的,Redis实际上处理的是一个个的字节,每个字节又如何去表示呢?不管编码字符集是什么,它有一个是不变的,就是ASCII码,其他已知的字符集(UTF-8,GBK)都是在ASCII码的基础上进行的扩展

ASCII 码表

在这里插入图片描述
通过对照表可以看到,字符1在ASCII里的表示 ,实际上赞同于十进制的49,转成二进制是 00110001,数一下,确实是3个1

  • NICE!那我就明白了,后面的start 和 end 明显就是二进制位的偏移么,如果我把start定为3 ,end 定为7,一定会返回2,因为从第四位到第八位,里面有两个1

在这里插入图片描述
在这里插入图片描述
-惊不惊喜?意不意外?是的,虽然bitcount是位级别的统计,但是它的参数并不是位级别的,而是字节级别的!

在这里插入图片描述

从上面可以得出几个结论

  1. bitcount是可以越界的,直接返回0
  2. 针对不存在的key,直接返回0
  3. 它的start,end参数在使用与含义上等于SETRANGE、GETRANGE,是字节级别的偏移

GETBIT

对 key 所储存的字符串值,获取指定偏移量上的位,怎么理解呢?看下面的例子。还是以1为例 ,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值