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是位级别的统计,但是它的参数并不是位级别的,而是字节级别的!
从上面可以得出几个结论
- bitcount是可以越界的,直接返回0
- 针对不存在的key,直接返回0
- 它的start,end参数在使用与含义上等于SETRANGE、GETRANGE,是字节级别的偏移
GETBIT
对 key 所储存的字符串值,获取指定偏移量上的位,怎么理解呢?看下面的例子。还是以1为例 ,